Java教程

【力扣每日一练总结】

本文主要是介绍【力扣每日一练总结】,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

每日一练

    • 1.题目与思路分析
    • 2.代码实现
    • 3.总结

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的方法的使用;欢迎大家将自己的解法分享出来,一起学习,共同进步;

这篇关于【力扣每日一练总结】的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!