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