不吉利日期

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

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在国外,每月的13号和每周的星期5都是不吉利的。特别是当13号那天恰好是星期5时,更不吉利。已知某年的一月一日是星期w,并且这一年一定不是闰年,求出这一年所有13号那天是星期5的月份,按从小到大的顺序输出月份数字。(w=1..7)

Input输入有一行,即一月一日星期几(w)。(1 <= w <= 7)Output输出有一到多行,每行一个月份,表示该月的13日是星期五。Sample Input
7
Sample Output
1
10
Hint1、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;
}
//还有一种方法是把每月天数加起来取模
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值