OJ链接—— 计算日期到天数转换

本文介绍了如何使用C语言编写程序,根据输入的四位数年份和日期计算该年的第几天,同时考虑闰年规则。通过逐月累加天数并处理闰年的特殊性,实现时间复杂度为O(n)和空间复杂度为O(1)的解决方案。
摘要由CSDN通过智能技术生成

1. 题目

1.1 题目描述

  • 根据输入的日期,计算是这一年的第几天。
  • 保证年份为4位数且日期合法。
  • 进阶:时间复杂度:O(n) ,空间复杂度:O(1)

1.2 输入描述

  • 输入一行,每行空格分割,分别是年,月,日

1.3 输出描述

  • 输出是这一年的第几天

2. 示例

在这里插入图片描述

在这里插入图片描述

3. 分析

  • 这道题简单解法其实将每个月的天数枚举出来,
  • 然后根据当前月份向前累加满月的天数,然后再加上当前月所在的天数。
  • 最终考虑平闰年的2月份区别是否增加一天
  • 其中需要注意的是平年和闰年的判断,
  • 而且是闰年的月份大于2的时候,也就是2月走完,总天数才能加1
  • 比如: 2000年2月18日,虽然是闰年,但是2月都没走完那是不能加上闰年多出的一天的

4. 完整代码

#include <stdio.h>

int is_leap_year(int year)
{
	if (year % 4 == 0 && year % 100 != 0 || year % 400 == 0)
	{
		return 1;
	}
	return 0;
}//判断是否为闰年

int main()
{
	int month_day[] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };
	int year, month, day;

	while (scanf("%d %d %d", &year, &month, &day) != EOF)
	{
		int total_day = day;//先把当前月份天数加上

		if (is_leap_year(year) == 1 && month > 2);
		{
			total_day++;
		}//若闰年且月份大于2,则在平年的基础上+1

		for (int i = month - 1; i > 0; i--)
		{
			total_day += month_day[i];//向前累加当月的天数即可
		}
		printf("%d\n", total_day);
	}
	return 0;
}
  • 运行结果:

在这里插入图片描述

最后,
恭喜你又遥遥领先了别人!
在这里插入图片描述

  • 8
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

看落日的YT

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值