c语言程序的设计年历显示_第1页
c语言程序的设计年历显示_第2页
c语言程序的设计年历显示_第3页
c语言程序的设计年历显示_第4页
c语言程序的设计年历显示_第5页
已阅读5页,还剩3页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

/XX航空航天大学金城学院设计题目年历显示学生姓名常思达学号2015023310专业班级20150233指导教师闵芳2016年3月4日目录TOC\o"1-2"\h\z\u一、课程设计问题描述11.课程设计题目12.设计任务要求1二、总体设计11.总体思路12.遇到的问题13.问题的解决14.大概的流程图1三、详细设计31.显示输入年份的日历32.显示所查询月份的日历43.判断当天是星期几,是否为法定假日4四、运行结果测试与分析51.输出结果52.分析7五、结论与心得7一、课程设计问题描述1.课程设计题目年历显示2.设计任务要求功能要求〔1输入一个年份,输出是在屏幕上显示该年的日历。假定输的年份在1940-2040年之间。〔2输入年月,输出该月的日历。〔3输入年月日,输出距今天还有多少天,星期几,是否是公历节日。二、总体设计1.总体思路想要实现输出某年的日历,必须知道一个常识,那就是公元一年一月一日是星期一,这是一个重要的切入点。如果知道了这一点,那问题就迎刃而解了。我们可以先计算出公元一年一月一日到这年一月一日之前的总天数,这用for语句较易实现,不过要注意到平年与闰年的区别。有了总天数,再除以7,余数是什么,那这年的一月一日就是星期几,如此依次写出一月的日历。然后一月的天数加上总天数得到的结果再除以7,如此知道二月一日是星期几,写出二月的月历。如此便可以依次写出一到十二月的日历。至于输入年月,输出该月的日历,思路相同。至于判断是否为公历节日,用一个if语句便可实现。2.遇到的问题〔1函数的调用与套用,具体来说就是如何在一个构造的函数中调用另一个构造函数。〔2把每月的日历设计的美观,如何让星期和下面的数字对齐。〔3如何把握日历的前几天的空格,使每月的第一天正好对在它应该的星期下。3.问题的解决第一个问题我通过查书,需要先把调用的函数在该构造函数中声明。至于第二和第三个问题,都是通过反复调试,反复修改,最后基本达到了要求。4.大概的流程图开始输入你查询的年份开始输入你查询的年份输入年月输入年月日和当前日期判断所输入的年份是否为闰年判断所输入的年份是否为闰年判断当天是星期几,是否为法定假日how<>,where<>how<>,where<>判断当天是星期几,是否为法定假日how<>,where<>how<>,where<>how<>,where<>,why<>,when<>输出该年的日历输入所查询月份的日历结束结束三、详细设计1.显示输入年份的日历当我们输入年份任意公元后的年份year时,可以通过一个for语句,算出从公元一年到year-1年的总天数,这其中要注意平年与闰年的区别,平年365天,闰年是366天,把这一部分用how<>函数表示。算出总天数Z后,用Z除以7,余数是d,则year这一年的一月一日便是星期d。如此则一月的日历可表示出来。然后把Z加上一月的天数tian得到的新值赋给Z,再用Z除以7,重新得到新的余数d,如此可知二月的第一天是星期几,可表示出二月的日历。依次循环,用for<i=0;i<12;i++>语句可表示出该年的日历。注意闰年二月是29天,平年是28天。开始开始输入year输入yearS=0,i=1S=0,i=1是否为闰年是否为闰年YNS=S+365S=S+366YNS=S+365S=S+366i++i++i<=yeari<=year输出s输出s结束结束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。调用when<>函数,可判断本日是否是法定假日。四、运行结果测试与分析1.输出结果2.分析在测试的过程中,基本都是一些语法上的缺陷,没有什么太大的逻辑错误,根据系统的提示,较易容易改正。还有就是在调试过程中,月份不够美观,基本是前后左右不能对齐,中间的空格不易把握。不过,在反复的调试与修改之后,最终实现了上面的效果。虽说不是太完美,也不至于太难看。附录#include<stdio.h>inthow<intA>{ inti,s=0,day; for<i=1;i<=A-1;i++>{if<i%4==0&&i%100!=0||i%400==0>day=366; else day=365; s=s+day;} returns;}intwhere<intB,intC>{ inttian; switch<C> { case1: tian=31;break; case2:if<B%4==0&&B%100!=0||B%400==0>tian=29; else tian=28;break; case3:tian=31;break; case4: tian=30;break; case5: tian=31;break; case6: tian=30;break; case7: tian=31;break; case8: tian=31;break; case9: tian=30;break; case10: tian=31;break; case11: tian=30;break; case12: tian=31;break; } returntian;}voidwhy<intE>{ switch<E> { case1:printf<"该日星期一\n">;break; case2:printf<"该日星期二\n">;break; case3:printf<"该日星期三\n">;break; case4:printf<"该日星期四\n">;break; case5:printf<"该日星期五\n">;break; case6:printf<"该日星期六\n">;break; case7:printf<"该日星期日\n">;break; }}voidwhen<intF,intG>{ if<F==1&&G==1||F==5&&G==1||F==10&&G==1>printf<"当天为法定节日">;elseprintf<"当天不是法定节日">;}voidmain<>{ intyear,d,j,Z,di,did,m,n,D,x,y,z,h,k,l,jian,Z1; printf<"输入你所查寻日历的年份:">; scanf<"%d",&year>; Z=how<year>;for<j=1;j<=12;j++>{ d=Z%7; printf<"~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n">; printf<"%d月份\n",j>; printf<"sunmontuewedthufrisat\n">; 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<"">; else printf<"">; 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<"%d月份\n",j>; printf<"sunmontuewedthufrisat\n">; 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<"">; else printf<"">; 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;j++> { D=where<x,j>; Z=Z+D; } Z=Z+z; printf<"输入当前年月日">;

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论