数。据。结。
构。课。程。设。
计。报。告。姓名。
专业班级。学号。
2023年7月13日。
题目:日历查询系统。
摘要:数据结构是计算机专业的教学计划中的核心课程之一,数据结构在计算机科学中是一门综合性的专业基础课。“数据结构”的研究不仅涉及到计算机硬件(特别是编码理论、存储装置和存取方法等)的研究范围,而且和计算机软件的研究有着更密切的关系,无论是编译程序还是操作系统,都涉及到数据元素在存储器中的分配问题。
本程序主要运用c语言来编写日历,通过给定的年,求该年的日历,闰年算法:||y%400==0 (用到数据结构知识)。输出公元1年至2023年的日历,能够实现以标准日历的形式输出,包含月份、星期以及具体某一天对应的年、月、星期,运用了用数据结构课上所学二叉树及队列顺序存储形式存储;
关键词:数据结构日历闰年二叉树队列。
一问题重述。
用c语言所编程序必须实现以下功能:
1)输入任一年将显示出该年的所有月份日期,对应的星期。
2)注意闰年情况。
其显示格式要求如下:
1)中文英文都可以。
2)下一行显示星期,从周日到周六,中英文都可以。
3)下一行开始显示日期从1号开始,并按其是周几实际情况与上面的星期数垂直对齐。
二、问题分析。
此日历输出的有效年份为:公元1年至2023年,必须以标准日历的形式输出,包含月份、星期以及具体某一天对应的年、月、星期,必须要用数据结构课上所学二叉树及队列顺序存储形式存储。
分析知万年历具有以下特点:
1、平年365天(52周+1天),闰年366天(52周+2天)。平年2月28天,闰年2月29天。
2、每400年整一闰,或每4年且不为百年的一闰。(原因:地球绕太阳一周的时间是365天5小时46秒,为了使一年的天数为整数,将一年的天数定为365天,余下的时间积累起来,四年就是23小时15分4秒,将近一天,把这一天加在某年的二月而成29天,该年称为闰年,其它年称为平年。
但四年加一天又多用了44分56秒,这个数积满400年为三天。因此400年中只能有97个闰年,所以凡能被400整除,或不能被100整除但能被4整除的年份为闰年。)
3、每 4年(3个平年+1个闰年)共208周+5天; 每百年共100*(208周+5天)-1天=5217周+5天 ;每400年共4*(5217周+5天)+1天(整400年闰)=20871周+0天——注意这个“0天”和“1天”(4个整百年只有一个闰年) 即400年一轮回!
三、程序的设计。
根据日历的特点进行编写程序:
1、首先对万年历年、月、日进行编写,编写程序先定义每月的天数为28天,如月份为就定义天数为31天反之如果月份为就输出天数为30天,由上可见2月份为28天但是如果为闰年就有29天就要定义一个数组存放天数,用while循环控制。
2、再对其中的星期进行编写:由于公元1月1日设为星期六,故3月1日为星期三,可以用万年3月1日星期算法(特别是那个三)
(1)闰年函数的定义:
int runnian( int year )
if ((year %4 ==0) &year % 100 !=0) |year % 400 ==0) )
return 1;
elsereturn 0;
2)判断星期的程序设计:
i = year_days % 7;
printf(" 日一二三四五六 ");
if( i !=0 )
for( temp_i = 0; temp_i < i; temp_i++)
printf("
day = 1;
3)用switch语句定义月份:
for( temp = 1; temp <=12; temp++
4)日期的输出。
if( runnian(year) &temp ==2)
while( day <=month[12] )
if( day >1 )
if( year_days % 7 ==0 )
printf(" n");
if( day >=10 )
printf("%3d ",day);
elseprintf("%3d ",day);
year_days++;
day++;
elsewhile (day <=month[temp-1])
if( day > 1 )
if( year_days % 7 ==0 )
printf("");
if( day >=10 )
printf("%3d ",day);
elseprintf("%3d ",day);
year_days++;
day++;
printf("");
printfn");
if( getch() q' )
exit(0);
getch();
四、程序源**。
#include <>
#include<>
#include<>
int runnian( int year )
if ((year %4 ==0) &year % 100 !=0) |year % 400 ==0) )
return 1;
elsereturn 0;
void main()
int i;
int day;
int year;
int temp;
int temp_i;
long int year_days = 0;
int yuannian = 1;
int days;
int month=
printf("请输入要查询的年份: "
scanf("%d",&year);
if(year<1||year>9999)
printf("输入错误,所查年份不存在。")
elsefor( temp = 1; temp <=12; temp++
switch( temp )
case 1:
printfn");
printf("(d)年1月日历",year);
break;
case 2:
printfn");
数据结构课程设计报告
东莞理工学院城市学院。题目 二叉排序树 专业 计算机科学与技术 本 年级 2010级计算机科学与技术专业 1 班。个人姓名 何振江。指导教师 张娟老师 时间 2010至2011第二学期第18周 地点 实验楼615机房 东莞理工学院城市学院计算机与信息科学系制。2011年 6月。实习报告的内容。一 问...
数据结构课程设计报告
设计一个校园导游程序,为来访的客人提供信息查询服务。1 设计学校的校园平面图。选取若干个有代表性的景点抽象成一个无向带权图 无向网 以图中顶点表示校内各景点,边上的权值表示两景点之间的距离。2 存放景点代号 名称 简介等信息供用户查询。3 为来访客人提供图中任意景点相关信息的查询。4 为来访客人提供...
数据结构课程设计报告
河北科技大学。课程设计报告。学生姓名学号。专业班级。课程名称数据结构。学年学期 2 012 2 013学年第 2 学期指导教师 黄春茹。2 0 13年 6 月。课程设计成绩评定表。一 数据结构课程设计目标。二 问题描述。三 需求分析。四 概要设计。五 详细设计。六 软件说明书 给出软件如何使用,使用...