版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、 信息学院课程设计题 目:年历处理程序的设计 学 号 201412150135 姓 名 杨浩頔 专 业 软件开发 课 程 程序设计基础(C) 指导教师 黄 超 2015年01月05日课程设计任务书及成绩评定题 目年历处理程序设计课程设计的任务及要求 多输入一个年份,输出实在屏幕上的该年的日历,假定输入的年份在1900-2099年之间;输入年月,输出该月的日历;输入年月日,输出距今还有多少天,星期几,是否为公历节日等。 课程设计所需的软件、硬件等软件:WIN-TC硬件: CPU>=1GHz 内存>=256M 硬盘>=20G课程设计进度计划2014年12月上旬,进行可行性研究,完
2、成选题. 2014年12月下旬,根据选题查阅资料、进行概要设计,确定设计方案. 2014年1月上, 详细设计,实施设计方案,编写程序、调试程序.2014年1月中,完成课程设计(任务书)的撰写。任课教师评语 成绩: 教师签名: 日期: 目录一、课程设计问题描述11.课程设计题目22.设计任务要求2二、总体设计1.总体思路22.遇到的问题23.问题的解决2三、详细设计1.显示输入年份的日历32.显示所查询月份的日历.33.判断当天是星期几,是否为法定假日.3四、运行结果测试与分析41.输出结果.42.分析5五、结论与心得.7课程设计问题描述1.课程设计题目年历显示2.设计任务要求功能要求(1)输入
3、一个年份,输出是在屏幕上显示该年的日历。假定输的年份在1 900-2099年之间。(2)输入年月,输出该月的日历。(3)输入年月日,输出距今天还有多少天,星期几,是否是公历节日。二、总体设计1.总体思路拿到题目,首先判断是否是闰年,利用一个if语句即可判断,同时注意2月份的天数不一样。2.遇到的问题(1)函数的调用与套用,具体来说就是如何在一个构造的函数中调用另一个构造函数。(2)把每月的日历设计的美观,如何让星期和下面的数字对齐。(3) 如何把握日历的前几天的空格,使每月的第一天正好对在它应该的星期下。(4)对于输入错误的年份时怎么样重新输入年份。3.问题的解决第一个问题我通过查书,需要先把
4、调用的函数在该构造函数中声明。至于第二和第三个问题还有第四个问题,都是通过反复调试,反复修改,最后基本达到了要求。三、详细设计1.显示输入年份的日历 当我们输入年份任意公元后的年份year时,可以通过一个for语句,算出从公元一年到year-1年的总天数,这其中要注意平年与闰年的区别,平年365天,闰年是366天,把这一部分用how()函数表示。算出总天数Z后,用Z除以7,余数是d,则year这一年的一月一日便是星期d。如此则一月的日历可表示出来。然后把Z加上一月的天数tian得到的新值赋给Z,再用Z除以7,重新得到新的余数d,如此可知二月的第一天是星期几,可表示出二月的日历。依次循环,用fo
5、r(i=0;i<12;i+)语句可表示出该年的日历。注意闰年二月是29天,平年是28天。2.显示所查询月份的日历当我们输入year和month时,同上,用how()函数算出公元一年一月一日到year-1年的总天数Z,再用一个for(i=1;i<month;i+)依次加上1月到month-1月的天数赋值给Z,用Z除以7得余数d,那本月的第一天便是星期几,便可表示出本月的日历。3.判断当天是星期几,是否为法定假日 当我们输入year,month和day,同上,算出从公元一年一月一日到month-1月以前的总天数Z,再加上day赋值给Z, 用Z除以7得余数d,那本天便是星期d。调用whe
6、n()函数,可判断本日是否是法定假日。四、运行结果测试与分析1.输出结果同时,我们为了提醒同学们注意输入数据的范围,特意添加了判断。2.分析在测试的过程中,基本都是一些语法上的缺陷,没有什么太大的逻辑错误,根据系统的提示,较易容易改正。还有就是在调试过程中,月份不够美观,基本是前后左右不能对齐,中间的空格不易把握。不过,在反复的调试与修改之后,最终实现了上面的效果。虽说不是太完美,也不至于太难看。但还是与课本要求有一定的差异。五、结论与心得当我第一次看到这个程序问题时,感觉比较容易,就选择了它。可当我仔细研究这个问题时,却傻了眼,没有我想象的那么简单。首先使我困惑的是每年的第一天是星期几怎么计
7、算,这使我郁闷了很久,一度没有头绪。后来,当我和同学交流时,知道了公元一年一月一日是星期一,这才恍然大悟。后来思路就有了,整个的过程也就想明白了。剩下的就是程序的编写与测试的过程了。在实际的编写过程中,也遇到了很多麻烦。不过,在一次次的调试与修改后,这些问题也一一克服。 要说我编写的这个代码,也有许多不尽如人意处。最大的问题是我是按照三个问题依次编下去,也就是说三个问题是连续的,如果你想要知道第三个问题,必须从第一个问题开始做下去,一直到第三个问题,不能直接出现第三个问题的结果。我一直在寻找一个办法,能够把三个问题分开,可很遗憾,直到现在,也未能成功。 通过这次编写这个代码,我知道了思考的重要
8、性,也明白了做任何事都不能轻易放弃,也不能轻易否决自己,多想想,多问一问,问题也许就解决了。附录一:系统的实现一:主流程图:开始输入你查询的年份输入年月输入年月日和当前日期判断所输入的年份是否为闰年how(),where()how(),where()how(),where(),why(),when()输出该年的日历输入所查询月份的日历结束二:判断是否为闰年开始输入yearS=0,i=1是否为闰年NYS=S+365S=S+366i+i<=year输出s结束三:判断是否为公历法定节日附录二:源代码#include <stdio.h>#include <stdlib.h>
9、;#include <stdio.h>int how(int A)int i,s=0,day;for (i=1;i<=A-1;i+) if (i%4=0 && i%100!=0 | i%400=0)day=366;elseday=365;s=s+day;return s;int where(int B,int C)int tian;switch(C) case 1:tian=31;break;case 2:if (B%4=0 && B%100!=0 | B%400=0)tian=29;elsetian=28;break;case 3: tian
10、=31;break;case 4:tian=30;break;case 5:tian=31;break;case 6:tian=30;break;case 7:tian=31;break;case 8:tian=31;break;case 9:tian=30;break;case 10:tian=31;break;case 11:tian=30;break;case 12:tian=31;break;return tian;void why(int E)switch(E)case 1: printf("该日星期一n");break;case 2: printf("
11、该日星期二n");break;case 3: printf("该日星期三n");break;case 4: printf("该日星期四n");break;case 5: printf("该日星期五n");break;case 6: printf("该日星期六n");break;case 7: printf("该日星期日n");break;void when(int F,int G)if (F=1 && G=1 | F=5 && G=1 | F=10 &a
12、mp;& G=1)printf ("当天为法定节日");elseprintf ("当天不是法定节日");void main()int year,d,j,Z,di,did,m,n,D,x,y,z,h,k,l,jian,Z1;loop:printf ("输入你所查寻日历的年份(19002099):");scanf ("%d",&year);if (year<1900|year>2099)printf("输入数据有误 请重新输入!n");if (year<1900|y
13、ear>2099)goto loop;Z=how(year);for (j=1;j<=12;j+)d=Z%7;printf("n");printf (" %d月份n",j);printf ("sun mon tue wed thu fri satn");if (d<6)for (di=1;di<=d+1;di+)printf(" ");for (did=1;did<=where(year,j);did+)printf ("%d",did);if (did<10
14、)printf (" ");elseprintf (" ");if (did=6-d | (did-6+d)%7=0 | did=where(year,j)printf ("n");Z=Z+where(year,j);printf ("输入所查日历的年月");scanf ("%d%d",&m,&n);Z=how(m);for (j=1;j<=n-1;j+)D=where(m,j);Z=Z+D;d=Z%7;printf("n");printf ("
15、; %d月份n",j);printf ("sun mon tue wed thu fri satn");if (d<6)for (di=1;di<=d+1;di+)printf(" ");for (did=1;did<=where(year,j);did+)printf ("%d",did);if (did<10)printf (" ");elseprintf (" ");if (did=6-d | (did-6+d)%7=0 | did=where(year,j)printf ("n");printf ("输入年月日");scanf ("%d%d%d",&x,&y,&z);Z=how(x);for (j=1;j<=y
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 中国石油大学(北京)《篮球》2023-2024学年第一学期期末试卷
- 郑州升达经贸管理学院《园林景观快题设计》2023-2024学年第一学期期末试卷
- 小学新课程标准培训方案
- 长春工业大学《葡萄酒品尝学》2023-2024学年第一学期期末试卷
- 生态恢复技术在退化土地上应用
- 餐饮业年度报告模板
- AI生活助手新品发布模板
- 硕士论文答辩报告
- 生医年报展望模板
- 房地产交易制度政策-《房地产基本制度与政策》全真模拟试卷4
- 《史记》上册注音版
- 健康管理师操作技能考试题库(含答案)
- 2018年湖北省武汉市中考数学试卷含解析
- 农化分析土壤P分析
- GB/T 18476-2001流体输送用聚烯烃管材耐裂纹扩展的测定切口管材裂纹慢速增长的试验方法(切口试验)
- GA 1551.5-2019石油石化系统治安反恐防范要求第5部分:运输企业
- 拘留所教育课件02
- 冲压生产的品质保障
- 2023年湖南联通校园招聘笔试题库及答案解析
- 上海市徐汇区、金山区、松江区2023届高一上数学期末统考试题含解析
- 护士事业单位工作人员年度考核登记表
评论
0/150
提交评论