蓝桥杯--年份处理

6 篇文章 0 订阅
4 篇文章 0 订阅

闰年:
1、年份非整百且能被4整除 (year % 4 = = 0 && year % 100 != 0)
2、年份能被400整除 (year%400 = = 0)
需要注意的是:能被100整除的数,必须能被400整除才算是闰年

question1:星期几

输入年月日,输出星期几
在这里插入图片描述

#include<iostream>
#include<cstring>
using namespace std;

int whatDay(int y, int m, int d){
	//	0-6
	int ans = 0;
	int i;
	int day[14] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
	for(i = 1; i < y; i++) {
		//计算走了多少年  加上对应天数 
		if((i % 100 != 0 && i % 4 == 0) || i % 400 == 0) {
			ans += (366 % 7);			
			ans %= 7;
		} else {
			ans += (365 % 7);			
			ans %= 7;
		}
	}
	
	if((y % 4 == 0 && y % 100 != 0) || y % 400 == 0) {
		day[2] = 29;
	} else {
		day[2] = 28; 
	}
	
	for(i = 1; i < m; i++) {
		//计算该年走了几个月  加上对应天数 
		ans += (day[i] % 7);
		ans %= 7;
	}
	
	ans += ((d-1) % 7);
	ans %= 7;
	return ans; 
}

int main(){
	string weekday[7] = {"星期一", "星期二", "星期三", "星期四", "星期五", "星期六", "星期日"};
	int y, m, d;
	while(cin>>y>>m>>d){
		cout<<weekday[whatDay(y, m, d)]<<endl;	
	}
	return 0;
}
question2:星期几

在这里插入图片描述在这里插入图片描述

int main(){
	int y, m, d, k;
	cin>>y>>m>>d>>k;
	int day[13] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
	if((y % 4 == 0 && y % 100 != 0) || y % 400 == 0) {
		day[2] = 29;
	}
	for(int i = 1; i <= k; i++) {
		d++;
		if(d == day[m] + 1) {
			d = 1;
			m++;
		}
		if(m == 13) {
			m = 1;
			y++;
			if((y % 4 == 0 && y % 100 != 0) || y % 400 == 0) {
				day[2] = 29;
			} else {
				day[2] = 28;
			}
		}
	}
	printf("%04d-%02d-%02d\n", y, m, d);
	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值