今天给各位分享c语言编程程第几天的知识,其中也会对c语言编程 后天是星期几进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!
本文目录一览:
1、C语言编程(程序怎样编写):给定年、月、日,计算该日是该年的第几天,然后计算该日是星期几。2、c语言编程输入第几天,计算第几月几日3、C语言编程:给定一个日期(年/月/日)计算该日期是所在年的第几天。4、用C语言编程 输入日期 输出这一天是该年的第几天
C语言编程(程序怎样编写):给定年、月、日,计算该日是该年的第几天,然后计算该日是星期几。
/**
程序描述:给定年、月、日,计算该日是该年的第几天,然后计算该日是星期几。
*/
#include stdio.h
int mon[]={31,28,31,30,31,30,31,31,30,31,30,31};
int leap_year(int n)
{
if(n%400==0||(n%4==0 n%100!=0))
return 1;
else
return 0;
}
int cal_dayCount(int year,int month,int day)
{
int i,sum;
for(i=0,sum=0;imonth-1;i++)
sum+=mon[i];
if(month2)
sum+=day+leap_year(year);
else
sum+=day;
return sum;
}
int cal_weekday(int year,int month,int day)
{
/**
蔡勒(Zeller)公式
历史上的某一天是星期几?未来的某一天是星期几?关于这个问题,有很多计算公式(两个通用计算公式和
一些分段计算公式),其中最著名的是蔡勒(Zeller)公式。
即w=y+[y/4]+[c/4]-2c+[26(m+1)/10]+d-1
公式中的符号含义如下,
w:星期;
c:年的高两位,即世纪-1
y:年的低两位;
m:月(m大于等于3,小于等于14,即在蔡勒公式中,某年的1、2月要看作上一年的13、14月来计算,
比如2003年1月1日要看作2002年的13月1日来计算);
d:日;
[ ]代表取整,即只要整数部分。
算出来的W除以7,余数是几就是星期几。如果余数是0,则为星期日。
如果结果是负数,负数求余数则需要特殊处理:
负数不能按习惯的余数的概念求余数,只能按数论中的余数的定义求余。为了方便
计算,我们可以给它加上一个7的整数倍,使它变为一个正数,然后再求余数
以2049年10月1日(100周年国庆)为例,用蔡勒(Zeller)公式进行计算,过程如下:
蔡勒(Zeller)公式:w=y+[y/4]+[c/4]-2c+[26(m+1)/10]+d-1
=49+[49/4]+[20/4]-2×20+[26× (10+1)/10]+1-1
=49+[12.25]+5-40+[28.6]
=49+12+5-40+28
=54 (除以7余5)
即2049年10月1日(100周年国庆)是星期5。
*/
int y, c, m, d;
int w;
if (month = 3)
{
m = month;
y = year % 100;
c = year / 100;
d = day;
}
else /* 某年的1、2月要看作上一年的13、14月来计算 */
{
m = month + 12;
y = (year – 1) % 100;
c = (year – 1) / 100;
d = day;
}
w = y + y / 4 + c / 4 – 2 * c + (26*(m+1))/10 + d – 1;
if (w 0) /* 如果w是负数,则计算余数方式不同 */
{
w = 7 – (-w) % 7;
}
else
{
w = w % 7; //如果w等于0,表示为星期天
}
return w;
}
int main()
{
int year,month,day;
int dayCount=0,i;
printf(“请输入当前的年,月,日: “);
scanf(“%d-%d-%d”,year,month,day);
printf(“该日是该年的第几天: %d\n”,cal_dayCount(year,month,day));
printf(“该日是星期几: %d\n”,cal_weekday(year,month,day));
return 0;
}
示例运行结果:
c语言编程输入第几天,计算第几月几日
#include stdio.h
main()
{
int year,day,d,m,leap;
int i;
int Month[12]={31,28,31,30,31,30,31,31,30,31,30,31};
printf(“输入年份和这一年的第多少天:\n”);
scanf(“%d”,year);
scanf(“%d”,day);
if( (year%4!=0) ||( (year%100==0) (year%400!=0)))
leap=0;//不是闰年
else
leap=1;//是闰年
if(leap==1)
Month[1]=29;//闰年二月29天
m=1;
for(i=0;i12;i++)
{
d=day-Month[i];
if(d0)
{
day=d;
m++;//月数加1
}
else
{
d = d+Month[i];
break;
}
}
printf(“The date is:%d年%d月%d日”,year,m,d);
}
C语言编程:给定一个日期(年/月/日)计算该日期是所在年的第几天。
//1.程序分析:以3月5日为例,应该先把前两个月的加起来,然后再加上5天即本年的第几天,特殊
//情况,闰年且输入月份大于3时需考虑多加一天。
#includestdio.h
void
main(){
int
year,month,day,i,leap;
int
fleap(int
a);
printf(“请输入年月日如(2009,1,1):”);
scanf(“%d,%d,%d”,year,month,day);
//printf(“%d,%d,%d\n”,year,month,day);
switch(month){
case
1:i=0;break;
case
2:i=31;break;
case
3:i=31+28;break;
case
4:i=31+28+31;break;
case
5:i=31+28+31+30;break;
case
6:i=31+28+31+30+31;break;
case
7:i=31+28+31+30+31+30;break;
case
8:i=31+28+31+30+31+30+31;break;
case
9:i=31+28+31+30+31+30+31+31;break;
case
10:i=31+28+31+30+31+30+31+31+30;break;
case
11:i=31+28+31+30+31+30+31+31+30+31;break;
case
12:i=31+28+31+30+31+30+31+31+30+31+30;break;}
leap=fleap(year);
if(leap==1)
{
i=i+day+1;
printf(“\n\n\n\n\n
%d年是润年\n”,year);}
else
{i=i+day;printf(“\n\n\n\n\n
%d年不是润年\n”,year);}
printf(“%d年%d月%d是%d年的第%d天”,year,month,day,year,i);
getch();}
int
fleap(int
a){
int
leap;
if(a%4==0)
{
if(a%100==0)
{
if(a%400==0)
leap=1;
else
leap=0;
}else
leap=1;
}
else
leap=0;
return(leap);}//判断润年的
用C语言编程 输入日期 输出这一天是该年的第几天
我大概给个思路,代码是现写的
没调试
先定义每个月的天数,2月按28天算
输入年月日后,根据年判断是否闰年(闰年加1天),再从1月加到当月的前一月,再加上日期就可以了
#include
int
month[12]
=
{31,28,31,30,31,30,31,31,30,31,30,31};
main()
{
int
yy,mm,dd,
days;
int
i;
printf(“input
year:”);
scanf(“%d”,
yy);
printf(“input
month:”);
scanf(“%d”,
mm);
printf(“input
day:”);
scanf(“%d”,
dd);
/*
如果大于2月,要做闰年的判断,忘了,不一定准
*/
if(
mm
2
((year%4==0
year%100!=0)
||
year%400==0)
)
days
=
1;
else
days
=
0;
/*
加上前面各整月的天数
*/
for(i
=
0;
i
mm-1;
i++)
days
+=
month[i];
/*
加上日数
*/
days
+=
dd;
printf(“this
is
the
%d
day
of
year
%d!!\n”,
days,
yy);
}
比如输入
1999
2
1
应该输出:this
is
the
32
day
of
year
1999!!
关于c语言编程程第几天和c语言编程 后天是星期几的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。