高级语言程序设计说明书-万年历系统_第1页
高级语言程序设计说明书-万年历系统_第2页
高级语言程序设计说明书-万年历系统_第3页
高级语言程序设计说明书-万年历系统_第4页
高级语言程序设计说明书-万年历系统_第5页
已阅读5页,还剩11页未读 继续免费阅读

下载本文档

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

文档简介

高级语言程序设计设计题目:万年历系统前言课程设计目的《高级语言程序设计》课程设计是电子信息、光信息专业以及物理学专业集中实践性环节之一,是学习完《高级语言程序设计》课程后进行的一次全面的综合练习,其目的在于加深对程序设计基本知识的理解,掌握使用C语言进行模块化软件设计的基本方法,提高通过编写程序解决实际问题的能力,为今后从事设计工作和后续各种编程课程的学习打好基础。一、问题重述设计:“万年历系统”要求:模仿现实生活中的挂历,编写程序要求当用户输入年份时能输出该年的日历,在日历上能够看出某天是星期几,可以显示任意一年任意一天,并能够知道是否是闰年等。二、功能要求1、判断一年是否为闰年;2、判断某年某月某日是星期几;3、显示一整年的日历;4、退出系统。三、设计目的1.通过本项课程设计,可以培养独立思考、综合运用所学有关相应知识的能力,能更好的巩固《C语言程序设计》课程学习的内容,掌握工程软件设计的基本方法,强化上机动手编程能力,闯过理论与实践相结合的难关!更加了解了c语言的好处和其可用性!同时增加了同学之间的团队合作精神!更加也体会到以后在工作中团队合作的重要性和必要性!2.通过C语言课程设计,使学生了解高级程序设计语言的结构,掌握基本的程序设计过程和技巧,掌握基本的分析问题和利用计算机求解问题的能力,具备初步的高级语言程序设计能力。为后续各门计算机课程的学习和毕业设计打下坚实基础。四、设计思想及过程【一】由于万年历具有以下特点:1。平年365天(52周+1天),闰年366天(52周+2天)。平年2月28天,闰年2月29天。由于公元1月1日设为星期六,故3月1日为星期三。——注意这个“三”为使算法达到最简,故本算法以“星期”为计算单位。且选3月1日为基月。2。每400年整一闰,或每4年且不为百年的一闰。(原因:地球绕太阳一周的时间是365天5小时46秒,为了使一年的天数为整数,将一年的天数定为365天,余下的时间积累起来,四年就是23小时15分4秒,将近一天,把这一天加在某年的二月而成29天,该年称为闰年,其它年称为平年。但四年加一天又多用了44分56秒,这个数积满400年为三天。因此400年中只能有97个闰年,所以凡能被400整除,或不能被100整除但能被4整除的年份为闰年。)所以百年%4=0闰或(年%4=0并且年<>0)闰。3。每4年(3个平年+1个闰年)共208周+5天每百年共100*(208周+5天)-1天=5217周+5天——注意这个“5天”——注意这个“5天”(整百年暂设为平年)每400年共4*(5217周+5天)+1天(整400年闰)=20871周+0天——注意这个“0天”和“1天”(4个整百年只有一个闰年)即400年一轮回!(原来万年历400年前是一家)【二】根据万年历以上特点进行编写:首先对万年历年、月、日进行编写,编写程序先定义每月的天数为28天,如月份为1、3、5、7、8、10、12就定义天数为31天反之如果月份为4、6、9、11就输出天数为30天,由上可见2月份为28天但是如果为闰年就有29天就要定义另一个函数#defineYear(x)(x%4==0&&x%100!=0||x%400==0)?1:0当为闰年时可得1加上该程序便可得到每月的天数。具体程序见(五、万年历程序)再对其中的星期进行编写:由于公元1月1日设为星期六,故3月1日为星期三,可以用万年3月1日星期算法(特别是那个三)由于其公式为:某年3月1日星期几=(3天+百年%4*5天+年/4*5天+年%4+月星期表+日-1天)%7某年3月1日星期几=(百年%4*5天+年/4*5天+年%4+月星期表+日+2天)%7或某年3月1日星期几=(百年%4*5天+年+年/4+月星期表+日+2天)%7闰4百年3月1日星期算法(百年%4=0)其公式为:某年3月1日星期几=(年+年/4+月星期表+日+2天)%7例:0000年3月1日星期几=(0+0/4+0+1+2)%7=3%7=星期三1600年3月1日星期几=(0+0/4+0+1+2)%7=3%7=星期三2000年3月1日星期几=(0+0/4+0+1+2)%7=3%7=星期三2001年3月1日星期几=(1+1/4+0+1+2)%7=4%7=星期四2004年3月1日星期几=(4+4/4+0+1+2)%7=8%7=星期一2008年3月1日星期几=(8+8/4+0+1+2)%7=13%7=星期六2042年3月1日星期几=(42+42/4+0+1+2)%7=55%7=星期六平4百年3月1日星期算法(百年%4<>0)其公式为:某年3月1日星期几=(百年%4*5天+年+年/4+月星期表+日+2天)%7例:1700年3月1日星期几=(17%4*5+0+0/4+0+1+2)%7=8%7=星期一(注意:1700年是平年)1800年3月1日星期几=(18%4*5+0+0/4+0+1+2)%7=13%7=星期六(注意:1800年是平年)1900年3月1日星期几=(19%4*5+0+0/4+0+1+2)%7=18%7=星期四(注意:1900年是平年)1901年3月1日星期几=(19%4*5+1+1/3+0+1+2)%7=19%7=星期五1918年3月1日星期几=(19%4*5+18+18/4+0+1+2)%7=(15+22+3)%7=40%7=星期五1958年3月1日星期几=(19%4*5+58/4*5+58%4+3)%7=(15+70+2+3)%7=90%7=星期六1988年3月1日星期几=(19%4*5+88/4*5+88%4+3)%7=(15+110+0+3)%7=128%7=星期二1999年3月1日星期几=(19%4*5+99/4*5+99%4+3)%7=(15+120+3+3)%7=141%7=星期一2100年3月1日星期几=(21%4*5+0/4*5+0%4+3)%7=(5+0+0+3)%7=8%7=星期一(注意:2100年是平年)2101年3月1日星期几=(21%4*5+1/4*5+1%4+3)%7=(5+0+1+3)%7=9%7=星期二2102年3月1日星期几=(21%4*5+2/4*5+2%4+3)%7=(5+0+2+3)%7=10%7=星期三2103年3月1日星期几=(21%4*5+3/4*5+3%4+3)%7=(5+0+3+3)%7=11%7=星期四2104年3月1日星期几=(21%4*5+4/4*5+4%4+3)%7=(5+1+0+3)%7=9%7=星期二(注意:2104年是闰年)9999年3月1日星期几=(99%4*5+99/4*5+99%4+3)%7=(120+15+3+3)%7=141%7=星期一注:按400年一轮回!(400年前是一家)的说法1600年,2000年是一样的;1700年,2100年是一样的;1800年,2200年是一样的;1900年,2300年是一样的。其中万年某日星期算法其公式为:某日星期几=(百年%4*5天+年+年/4+月星期表+日+2天)%7通同星期偏差表闰年1月2月3月4月5月6月7月8月9月10月11月12月天数312931303130313130313031星期360351362402平年1月2月3月4月5月6月7月8月9月10月11月12月天数312831303130313130313031星期400351362402为对以上的万年历星期的算法是正确的对其进行了以下的计算:⒈对于二十世纪任意日期可以用公式某日星期几=(百年%4*5天+年+年/4+平年月星期表+日+2天)%7=(19%4*5天+年+年/4+平年月星期表+日+2天)%7=(15天+年+年/4+平年月星期表+日+2天)%7以下就是根据上面对其进行的计算:1900年元旦1月表=4(平年)故4+4=1即1900年元旦是星期一1949年国庆1日=(49/4*5+49%4+1+3)%7=(60+1+4)%7=21日=(0/4*5+0%4+1+3)%7=(0+0+4)%7=410月表=4(平年)故4+2=6即1949年国庆是星期六1999年12月31日31日=(99/4*5+99%4+31+3)%7=(120+3+34)%7=312月表=2(平年)故2+3=5即1999年12月31日是星期五⒉对于二十一世纪新前年虫算法(20%4*5=0)可以用公式:某日星期几=(百年%4*5天+年+年/4+闰年月星期表+日+2天)%7=(20%4*5天+年+年/4+闰年月星期表+日+2天)%7以下就是根据上面对其进行的计算:2000年元旦1日=(0+0/4+1+2)%7=(0+0+1+2)%7=31月表=3(闰年)故3+3->6即2027年元旦是星期六2018年春节16日=(18+18/4+16+2)%7=(18+4+16+2)%7=52月表=0(平年)故0+5=5即2018年春节是星期五2099年12月31日31日=(99/4*5+99%4+31+2)%7=(120+3+33)%7=212月表=2(平年)故2+2=4即2099年12月31日是星期四对于上面的分析以及公式的推论和计算证明可以对万年历中的星期进行了编写具体编写程序见(五、万年历程序)中。五、个性化设计1.增加被查询日期是否存在的判断。例如:2011年2月29日这天是不存在的,因为2011年不是闰年(leapyear)。输入查询日期,则输出结果如下:日期不存在时系统的人性化提示为:连续输入多次不存在的日期,系统就发飙了,先清屏,说“别玩我,你是外星人嘛??”其他常用的不存在日期(如month大于12,day大于31(自然有的是30、28、19),year小于0的)也能判断。好处是减少了因为盲目套用判断带来的误判(即无论日期是什么都输出一个它是什么date)。2.增加简易心情系统,完善选择。增加了简单的累计输入有误的计算,输入不和要求次数太多系统会有不同反应;同时完善了选择模式,即不再选项范围内的判断及提醒,同样累计。例子1:A.主界面选择的输入有误B.提示在(1,2,3or4)中再次选择,下次选对之后需要确认。如图:选对3之后系统提示如下。C.连续多次选择错误,系统就发飙了,先清屏,说“确认好你的选择!!”然后继续选择。注:其他输入(如选择Yy/Nn)有误时类似,展示如下。次数多后:个性化功能总结:此思想为人工神经网络(ArtificialNeuralNetworks)的简易,相当于传递函数为简单的累加,思维判断仅为判断累加的大小,且系统情绪发泄完后自动清空累加值。相当于一条很简单的神经。在此基础上改变网络类型,增加神经元,丰富传递函数,增强判断的逻辑性,添加记忆机制,这样神经的思维模式更接近大脑,能做复杂的决定,可以记忆,就能做出复杂的神经。人工神经网络(ArtificialNeuralNetworks)的应用将成为人工智能的基石。六、附录以下是源代码(TV环境),VC环境(特殊要求可能需要)中只要稍作更改,这里便不再赘述。#include"stdio.h"#include"conio.h"intisleapyear(intyear){if((year%4==0&&year%100!=0)||year%400==0)return1;elsereturn0;}voiddisplay1(intyear){intmon=1,da=1,x,i;x=whatdate(calculate(year,mon,da));for(i=1;i<=12;i++){printf("Month%dth:\n",i);x=display2(year,i,x);printf("\n\n");}}intdisplay2(intyear,intmonth,intx){inti;printf("SUNMONTUEWENTHUFRISAT\n");disp3(x+1);for(i=1;i<=month_day(year,month);i++){if(x>6){x=0;printf("\n");}x++;printf("%8d",i);disp3(1);}returnx;}intdisp3(intn){inti=1;while(i<n){printf("");i++;}}intcalculate(intyear,intmonth,intday){inti,s=0;for(i=1;i<year;i++){s=s+365+isleapyear(i);}for(i=1;i<month;i++){s=s+month_day(year,i);}s=s+day;return(s);}intwhatdate(intsum1){intsum;sum=calculate(2011,11,11);if((sum1-sum+5)%7>=0)return((sum1-sum+5)%7);elsereturn((sum1-sum+5)%7+7);}intmonth_day(intyear,intmonth){intdaymax[12]={31,28,31,30,31,30,31,31,30,31,30,31};if(isleapyear(year)&&month==2)return29;elsereturndaymax[month-1];}main(){intdaymax[12]={31,28,31,30,31,30,31,31,30,31,30,31},opt,add=0,sum;/*add为累计心情值为个性化做铺垫*/intyear,month,day;charch;char*month_str[]={"January","February","March","April","May","June","July","August","September","October","November","December"};char*week[]={"Sunday","Monday","Tuesday","Wednesday","Thurday","Friday","Saturday"};printf("Welcometomyperpetualcalendar.\n\n@@director&Designer:HanShuai~@@\n\n\n");while(1){printf("Pleaseselecttheserviceyouneed:\n\n1Searchwhethertheyearisleapyearornot.\n2Searchwhatdaythedayis\n3Printthecalanderofthewholeyear\n4Exit\n");scanf("%d",&opt);fflush(stdin);/*cleanuptheCachememory*/switch(opt){case1:{printf("Pleaseinputayear:XXXX\n");scanf("%d",&year);fflush(stdin);/*cleanuptheCachememory*/clrscr();/*cleanscreen*/printf("\t\t%dis",year);if(isleapyear(year)==0)printf("not");printf("alaepyear.\n\n\n\n");}break;case2:{printf("Pleaseinputyouryear&month&dayinmind:XXXX,XX,XX\n");scanf("%d,%d,%d",&year,&month,&day);fflush(stdin);/*cleanuptheCachememory*/if(year<0||month<0||month>12||day<=0||day>month_day(year,month))do{add++;printf("\tWARING::\n\tTheday:%d-%d-%disnotexist~.~!!!!\n\nPleaseinputyouryear&month&dayinmind:XXXX,XX,XX\n",year,month,day);scanf("%d,%d,%d",&year,&month,&day);fflush(stdin);/*cleanuptheCachememory*/while(add>4){clrscr();/*cleanscreen*/printf("\tDonotplaywithme.\n\tAreyououtofearth??\n\n");/*连续输入多次不存在的日期,系统就发飙了,先清屏,说“别玩我,你是外星人嘛??”*/add=0;}}while(year<0||month<0||month>12||day<=0||day>daymax[month_day(year,month)]);add=0;/*恢复心情值*/printf("\n\tThedate%d-%d-%dis%s.\n",year,month,day,week[whatdate(calculate(year,month,day))]);}break;case3:{printf("\tPleaseinputyouryearyouwantdisplay:XXXX\n");scanf("%d",&year);display1(year);}break;case4:{add=0;printf("\tAreyousure??((Y/N)");scanf("%c",&ch);fflush(stdin);/*cleanuptheCachememory*/if(ch=='y'||ch=='Y')exit(0);while(ch!='N'&&ch!='n'){add=add++;printf("\tYougetb

温馨提示

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

评论

0/150

提交评论