【力扣每日一练总结】

每日一练

1.题目与思路分析

1154. 一年中的第几天

给你一个字符串 date ,按 YYYY-MM-DD 格式表示一个 现行公元纪年法 日期。请你计算并返回该日期是当年的第几天。
通常情况下,我们认为 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 日

分析:题目要求我们根据所给年月日统计当前这一天是一年中的第几天;所以我们先要找到一年中12个月每一个月中天数的特点;1,,3,5,7,8,10,12是31天,4,6,9,11是30天,2月分为闰月是29天,平常为28天。搞清楚这个我们就可以将所给日期的字符串使用substring()获取到所需要的年月日字符串,再通过Integer.parseInt()强转就可以得到数字;我们使用for循环,在里面利用switch case 语句进行天数的计算,当为2月时再加一个if语句进行闰月的判断就完成了。

2.代码实现

class Solution {
    public int dayOfYear(String date) {
        int year = Integer.parseInt(date.substring(0,4));
         int month = Integer.parseInt(date.substring(5,7));
         int day = Integer.parseInt(date.substring(8));
         int days = 0;
         for(int i = 1;i<month;i++){
             switch(i){
                 case 1:
                 case 3:
                 case 5:
                 case 7:
                 case 8:
                 case 10:
                 case 12: days += 31;
                 break;
                 case 4:
                 case 6:
                 case 9:
                 case 11: days += 30;
                 break;
                 case 2: 
                    if((year % 400 == 0) || (year % 4 == 0 && year % 100 != 0)){
                        days += 29;
                    }else{
                        days += 28;
                    } 
                    break;
                 default:
                 break;
             }
         }
         days = days + day;
         return days;
    }
}

【力扣每日一练总结】

3.总结

这道题考察的是最基础的循环的练习以及String的方法的使用;欢迎大家将自己的解法分享出来,一起学习,共同进步;

上一篇:记一次 .NET 某市附属医院 Web程序 偶发性CPU爆高分析


下一篇:过“我的学号后两位”天是星期几?