编写一个程序,只要输入年月日,就能回答那天是星期几

[实验提示]1、已知公元1年1月1日是星期一2、算法提示:如果输入的是2006年3月12日,计算方法是(1)先计算从公元0001年初(0001-1-1)到2005年末(2... [实验提示]
1、已知公元1 年1 月1 日是星期一
2、算法提示:如果输入的是2006 年3 月12 日,计算方法是
(1) 先计算从公元0001 年初(0001-1-1)到2005 年末(2005-12-31)共多少天,注意其中
有闰年,闰年是366 天,平年是365 天。闰年的判断条件满足:
(( year%4==0 && year%100!=0 )!!(year%400==0))
(2) 然后再计算2006 年1 月1 日到2006-3-12 是多少天。注意同样判断本年度是否闰年,
即二月份是28 天还是29 天。
(3) 上述两部分相加即从公元0001 年初(0001-1-1)到2006 年末(2006-3-12)的天数,
用该天数模7(total%7)即得到星期数。
展开
 我来答
科举网7号助教
推荐于2017-11-23 · TA获得超过349个赞
知道答主
回答量:129
采纳率:0%
帮助的人:194万
展开全部
#include <stdio.h>

/* 检验该年是否为闰年 */
bool Leap(int year)
{
if((year%4==0 && year%100!=0 )||(year%400==0))
return true;
else
return false;
}

int Day(int y,int m,int d)
{
int i,n=1;
/* 计算该年份(如2010年)1月1日是星期几 */
for(i=1;i<y;i++)
{
if(Leap(i))
n = (n+366)%7;
else
n = (n+365)%7;
}
/* 计算该月份1日是星期几 */
for(i=1;i<m;i++)
{
switch(i)
{
case 2:
if(Leap(y)) n = (n+29)%7;
else n = (n+28)%7;break;
case 4:case 6:case 9:case 11:
n = (n+30)%7;break;
default:
n = (n+31)%7;break;
}

}
/* 最后,计算这一天是星期几 */
n = (n+d-1)%7;
return n;
}

int main()
{
//如果n=0,代表是星期日
printf("%d\n",Day(2010,9,12));
return 0;
}
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式