蓝桥杯--年份处理

闰年:
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;
}

猜你喜欢

转载自blog.csdn.net/weixin_44227389/article/details/107877919
今日推荐