K - 中等难度暴力(计算天数)

蒜头君给定两个日期,请计算相差的天数。比如 2010-1-1 和2010-1-3 相差 2 天。

输入格式

共两行:

第一行包含三个整数 startYearstartYear,startMonthstartMonth,startDaystartDay,分别是起始年、月、日。

第二行包含三个整数 endYearendYear,endMonthendMonth,endDayendDay,分别是结束年、月、日。

相邻两个整数之间用单个空格隔开。

年份范围在 1∼3000。保证日期正确且结束日期不早于起始日期。

输出格式

输出一个整数,即是两个日期相差的天数。

Sample Input

2008 1 1
2009 1 1

Sample Output

366

说来这种题目也简单,比较年月日的差距然后进行计算,不过坐起来也真的很麻烦。

首先想到的一定是要考虑闰年和平年吧。

之后便是比较念数差距,月份差距,日期差距。

最后算出所差天数。

#include <stdio.h>
 
int main() {
	int a, b, c;  //起始年份
	int x, y, z;  //终止年份
	int m[13] = {0, 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 30}; //闰年
	int n[13] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 30};//非闰年
	scanf("%d %d %d", &a, &b, &c);
	scanf("%d %d %d", &x, &y, &z);
	int k = 0, i;
	if (a % 4 == 0 && a % 100 != 0 || a % 400 == 0) { //判断起始年份是否为闰年
		for (i = b; i <= 12; i++) {    //将该闰年年份剩下每月天数加起来
			k += m[i];
		}
	} else {
		for (i = b; i <= 12; i++) {  //将该非闰年年份剩下每月天数加起来
			k += n[i];
		}
	}
	k = k - c; //减去起始年份的c即得到该年剩下的天数
	while (a != x - 1) { //加上起始和终止年份间相差的年数
		a++;
		if (a % 4 == 0 && a % 100 != 0 || a % 400 == 0) { //相差年份中闰年加366非闰年加365
			k += 366;
		} else {
			k += 365;
		}
	}
	int j;
	if (x % 4 == 0 && x % 100 != 0 || x % 400 == 0) {//判断终止年份是否为闰年
		for (j = 1; j < y; j++) {   //加上终止年份月份
			k += m[j];
		}
	} else {
		for (j = 1; j < y; j++) {
			k += n[j];
		}
	}
	printf("%d", k + z + 1);  //输出结果加上终止年份的z日
	return 0;
}

上一篇:Centos8 二进制安装MariaDB-10.2.31


下一篇:Redis | 第8章 发布订阅与事务《Redis设计与实现》