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;
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值