Leetcode刷题-字符串1154:一年中的第几天

该文章介绍了一个LeetCode的编程题目,要求根据输入的日期字符串(YYYY-MM-DD格式)确定该日期在当年的第几天。解决方案包括两种方法:一是手动计算,通过判断闰年并构建月份天数数组;二是使用Python的time模块解析日期。两种方法中,手动计算更被推荐。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目

给你一个字符串 date ,按 YYYY-MM-DD 格式表示一个 现行公元纪年法 日期。返回该日期是当年的第几天。

示例1:

输入:date = "2019-01-09"
输出:9
解释:给定日期是2019年的第九天。

示例2:

输入:date = "2019-02-10"
输出:41

提示:

(1)date.length == 10
(2)date[4] == date[7] == '-',其他的 date[i] 都是数字
(3)date 表示的范围从 1900 年 1 月 1 日至 2019 年 12 月 31 日

分析思路

本题需要注意的点在于:

1、判断年份是否为闰年(能被400整除,或者能被4整除但不能被100整除);

满足以下两个条件的整数才可以称为闰年:
(1)普通闰年:能被4整除但不能被100整除(如2004年就是普通闰年);
(2)世纪闰年:能被400整除(如2000年是世纪闰年,1900年不是世纪闰年);

2、输入的日期为字符串类型,如何提取年、月、日(考虑利用切片);

3、如何进行计算(将提取的字符串转换为数值型int)。

整体思路:

法一:将每个月份的天数以数组存放(2月份天数按28天记),判断当前年份是否为闰年,若为闰年,则将自定义数组中2月份的天数改为29,接着利用切片计算已度过的月份天数+当月天数。

class Solution(object):
    def dayOfYear(self, date):
        
        #每月天数存为数组,注意7、8月天数均为31天
        days = [0,31,28,31,30,31,30,31,31,30,31,30,31,30]

        #判断当前年份是否为闰月,若是,将2月份的天数换成29天
        now_year = int(date[:4])
        if now_year % 4 == 0 and now_year % 100 != 0 or now_year % 400 == 0 :
            days[2]=29
        
        #计算天数
        res = sum(days[ : int(date[5:7])])+int(date[8:])
        return res

LeetCode参考答案:

class Solution(object):
    def dayOfYear(self, date):
        """
        :type date: str
        :rtype: int
        """
        def check(year):
            if year % 100 == 0:
                return year % 400 == 0
            return year % 4 == 0
        days = [0, 31,28,31,30,31,30,31,31,30,31,30,31]
        if check(int(date[:4])):
            days[2] = 29
        
        return sum(days[:int(date[5:7])]) + int(date[8:])

 法二 (不推荐):

利用time.strptime() 函数,函数根据指定的格式把一个时间字符串解析为时间元组

语法:

time.strptime(string[, format])

使用方法:

import time
 
struct_time = time.strptime("30 Nov 00", "%d %b %y")
print "返回的元组: %s " % struct_time

运行结果:

返回的元组: time.struct_time(tm_year=2000, tm_mon=11, tm_mday=30, tm_hour=0, tm_min=0, tm_sec=0, tm_wday=3, tm_yday=335, tm_isdst=-1) 

本题用该法解题代码如下:

import time
class Solution(object):
    def dayOfYear(self, date):
        """
        :type date: str
        :rtype: int
        """
        return time.strptime(date, "%Y-%m-%d")[-2]

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值