1154 一年中的第几天(模拟)

1. 问题描述:

    给你一个按 YYYY-MM-DD 格式表示日期的字符串 date,请你计算并返回该日期是当年的第几天。通常情况下,我们认为 1 月 1 日是每年的第 1 天,1 月 2 日是每年的第 2 天,依此类推。每个月的天数与现行公元纪年法(格里高利历)一致。

示例 1:
输入:date = "2019-01-09"
输出:9

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

示例 3:
输入:date = "2003-03-01"
输出:60

示例 4:
输入:date = "2004-03-01"
输出:61

提示:
date.length == 10
date[4] == date[7] == '-',其他的 date[i] 都是数字。
date 表示的范围从 1900 年 1 月 1 日至 2019 年 12 月 31 日。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/day-of-the-year

2. 思路分析:

我们只需要使用split函数对日期进行分割,对于得到的年份判断是否是闰年来确定2月份的数量,通过循环累加每月的天数即可

3. 代码如下:

class Solution:
    def dayOfYear(self, date: str) -> int:
        # 使用split函数进行分割, 得到的是str类型 
        date = date.split("-")
        # 是否是闰年, int函数将str类型转为int类型
        res, year, isleap = 0, int(date[0]), 0
        months = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]
        if (year % 4 == 0 and year % 100 != 0) or (year % 400 == 0):
            isleap = 1
        for i in range(1, int(date[1])):
            if isleap == 1 and i == 2: res += isleap
            res += months[i - 1]
        return res + int(date[2])

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值