在国外,每月的13号和每周的星期5都是不吉利的。特别是当13号那天恰好是星期5时,更不吉利。已知某年的一月一日是星期w,并且这一年一定不是闰年,求出这一年所有13号那天是星期5的月份,按从小到大的顺序输出月份数字。(w=1..7)
Input输入有一行,即一月一日星期几(w)。(1 <= w <= 7)Output输出有一到多行,每行一个月份,表示该月的13日是星期五。Sample Input7Sample Output
1 10Hint1、3、5、7、8、10、12月各有31天
4、6、9、11月各有30天
2月有28天
#include<stdio.h>
int main()
{
int w, i;
int one[12] = {6, 2, 2, 5, 7, 3, 5, 1, 4, 6, 2, 4};
int two[12] = {7, 3, 3, 6, 1, 4, 6, 2, 5, 7, 3, 5};
int three[12] = {1, 4, 4, 7, 2, 5, 7, 3, 6, 1, 4, 6};
int four[12] = {2, 5, 5, 1, 3, 6, 1, 4, 7, 2, 5, 7};
int five[12] = {3, 6, 6, 2, 4, 7, 2, 5, 1, 3, 6, 1};
int six[12] = {4, 7, 7, 3, 5, 1, 3, 6, 2, 4, 7, 2};
int seven[12] = {5, 1, 1, 4, 6, 2, 4, 7, 3, 5, 1, 3};
scanf("%d",&w);
switch (w)
{
case 1:
{
for(i=0;i<12;i++)
if(monday[i]==5) printf("%d\n",i+1);
break;
}
case 2:
{
for(i=0;i<12;i++)
if(two[i]==5) printf("%d\n",i+1);
break;
}
case 3:
{
for(i=0;i<12;i++)
if(three[i]==5) printf("%d\n",i+1);
break;
}
case 4:
{
for(i=0;i<12;i++)
if(four[i]==5) printf("%d\n",i+1);
break;
}
case 5:
{
for(i=0;i<12;i++)
if(five[i]==5) printf("%d\n",i+1);
break;
}
case 6:
{
for(i=0;i<12;i++)
if(six[i]==5) printf("%d\n",i+1);
break;
}
case 7:
{
for(i=0;i<12;i++)
if(seven[i]==5) printf("%d\n",i+1);
break;
}
}
return 0;
}//还有一种方法是把每月天数加起来取模

本文提供了一种使用C语言解决特定日期问题的方法,通过预定义数组来判断每年各月13号为星期五的情况,适用于非闰年的日期计算。针对不同初始星期,文章提供了详细的代码实现。
1194

被折叠的 条评论
为什么被折叠?



