c语言设计万年历

c语言设计万年历,第1张

/*不过除了没有查询某年某月某日是这一年的第几天。。和判断这一年的生肖外,都能满足你的要求。

加点金币帮你完善点!*/

#include<stdio.h>

int

Swiss(int

Years)

//判断是否是闰年

{

if(!(Years%100))

{

Years=Years/100

}

if(Years%4)

{

return

0

}

else

{

return

1

}

}

int

Number(int

Yearsa,int

Yearsb)

//已知两个年份,求出两个年份之间闰年的个数

{

int

i=Yearsa+1

int

mou=0

do{

if(Swiss(i))

{

mou++

}

i++

}while(i<Yearsb)

return

mou

}

int

Mvalue(int

Years,int

Month,int

Day)

//已知年月日,求出某年某月某日是星期几

{

int

M[12]={0,3,3,6,1,4,6,2,5,0,3,5}

//月值

int

N=6

//年值初始化

int

a

if(Years<2006)

//求年值,年值以2006年为基数

{

N=6-((2006-Years)%7)-Number(Years,2006)

if(Swiss(Years))

{

if(Month<3)

{

N--

}

}

}

else

if(Years>2006)

{

N=((Years-2006)%7)-1+Number(2006,Years)

if(Swiss(Years))

{

if(Month>2)

{

N++

}

}

}

a=(Day+M[Month-1]+N)%7

//某年某月某日是星期几=(日值+月值+年值)%7

return

a

}

int

Amonth(int

Month)

//已知月,求出这个月是大月还是小月

{

switch(Month)

{

case

1:

case

3:

case

5:

case

7:

case

8:

case

10:

//1,3,5,7,8,10,12是大月,没月31天

case

12:return

1

case

4:

case

6:

case

9:

case

11:return

0

//4,6,9,11是小月,每月30天

case

2:return

2

//二月份

}

return

-1

}

void

main

()

{

int

Dtable[7][7]

int

i,j

int

Years=9999

int

Month=12

int

Day=1

int

b

for(i=0i<7i++)

//初始化数组

{

Dtable[0][i]=i

}

for(i=1i<7i++)

{

for(j=0j<7j++)

{

Dtable[i][j]=0

}

}

i=Mvalue(Years,Month,Day)

switch(Amonth(Month))

{

case

0:b=30break

case

1:b=31break

case

2:if(Swiss(Years))b=29else

b=28break

//闰年2月29天,平年二月28天

default:b=-1break

}

for(i<7i++)

{

Dtable[1][i]=Day++

}

for(i=2i<7i++)

{

for(j=0j<7j++)

//建造日历表

{

if(Day<=b)

{

Dtable[i][j]=Day++

}

else

{

continue

}

}

}

printf("%d:%d\n",Years,Month)

for(i=0i<7i++)

//输出日历表

{

for(j=0j<7j++)

{

printf("%3d",Dtable[i][j])

}

printf("\n")

}

getch()

//完毕!

}

#include <stdio.h>

int leap (int year)

{if(year%4==0&&year%100!=0||year%400==0) //判断是否是闰年

return 1

else return 0

}

int days_month (int month,int year) //判断大月和小月

{

if(month==1||month==3||month==5||month==7||month==8||month==10||month==12) //找出大月

return 31

if(month==4||month==6||month==9||month==11) //找出小月

return 30

if(month==2&&leap(year)==1) return 29//判断二月是29天还是29天

else return 28

}

int firstday(int month,int year)

{int w

w=(1+2*month+3*(month+1)/5+year+year/4+year/400-year/100)%7+1//判断每个月开始的第一天是星期几

return w

}

main()

{int i,j=1,k=1,a,b,month,year

printf("\n input month and year:\n")

scanf("%d%d",&month,&year)//输入月和年

b=days_month(month,year)

a=firstday (month,year)

printf(" Sun Mon Tue Wed Thu Fri Sat \n")//输出对应当月的日历

if(a==7)

{for(i=1i<=bi++)

{printf("%4d",i)

if(i%7==0)

{printf("\n")

}

}

}

if(a!=7)

{while (j<=4*a)

{printf(" ")

j++

}

for(i=1i<=bi++)

{printf("%4d",i)

if(i==7*k-a)

{printf("\n")

k++

}

}

}

printf("\n")

}

实验名称:万年历的查询及打印

【内容】:设计一个查询并打印万年历的程序。

【步骤】:

1.

画出程序流程图;

2.

编写程序;

3.

调试程序,对调试过程中出现的问题进行分析,找出错误的原因并予改正;

4.

写出通过调试并修改正确的原程序。

【要求】:

1.

程序运行后,首先在屏幕上显示主菜单:

1.

查询某年某月某日是星期几

2.

查询某年是否是闰年

3.

打印某年的全年日历

4.

退出

2.

在主菜单中输入1后,显示:

请输入年月日(XXXX,XX,XX)”

运行后输出:XXXX年XX月XX日是星期X,是否继续查询(Y/N)?

如果输入Y,则重新显示

“请输入年月日(XXXX,XX,XX)”,否则回到主菜单。

3.

在主菜单中输入2后,显示:

“请输入要查哪一年?(XXXX)”

运行后输出:XXXX年是(否)是闰年,是否继续查询(Y/N)?

如果输入Y,则重新显示,“请输入要查哪一年?(XXXX)”,否则回到主菜单。

4.

在主菜单中输入3后,显示:

“请输入要打印的年份(XXXX)”

运行后输出XXXX年的日历,格式为:

XXXX

X(月数)

0

1

2

3

4

5

6

S

M

T

W

T

F

S

x

x

x

x

x

x

x

x

x

x

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

X(月数)

0

1

2

3

4

5

6

S

M

T

W

T

F

S

x

x

x

x

x

x

x

xx

 xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

xx

.

.

.

.

.

 运行完后显示:“是否继续打印(Y/N)?”

 如果输入Y,则重新显示,“请输入要打印的年份(XXXX)”,否则回到主菜单。

5.

在主菜单中输入4后,显示:“是否要真的退出(Y/N)?”

如果输入Y,结束程序运行,否则重新显示主菜单。

【提示】:

1.

闰年计算:满足下列二者之一,是闰年:

能被4整除,但不能被100整除

能被4整除,且能被400整除。

2.闰年的二月是29天,平年的二月是28天

3.星期几的计算:

S=X-1+(X-1)/4+(X-1)/100+(X-1)/400+C

X是年份,C是该年从元旦开始到到这一日的天数。

S/7的余数既是星期数

例1:1982年12月26日

由于1982年不是闰年(不能被4整除),所以该年的二月是28天。

C=31+28+31+30+31+30+31+31+30+31+30+26=360

(1月到11月的天数+12月的实际天数)

S=1982-1+(1982-1)/4+(1982-1)/100+(1982-1)/400+360=2821.3925

S/7=2821/7=403

余数为0,所以该日是星期天。

例2:2000年3月8日

由于2000年是闰年(能被4整除,又能被100和400整除),所以该年的二月是29天。

C=31+29+8=68

(1月到2月的天数+3月的实际天数)

S=2000-1+(2000-1)/4+(2000-1)/100+(2000-1)/400+68=2551.757

S/7=2551/7=364

余数为3,所以该日是星期三。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/11123358.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-13
下一篇 2023-05-13

发表评论

登录后才能评论

评论列表(0条)

保存