一年中的第幾天

對於要求輸入的是整形的題即可用下面的C++版本

#include <bits/stdc++.h>

using namespace std;

int main(void)
{
	int y, m, d, num[12] = { 31,28,31,30,31,30,31,31,30,31,30,31 }, da = 0;
	cin >> y >> m >> d;
	if (y % 4 == 0 && y % 100 != 0 || y % 400 == 0)
	{
		if (m <= 2)
		{
			for (int i = 0; i < m - 1; i++)da += num[i];
			da += d;
		}
		else
		{
			for (int i = 0; i < m - 1; i++)da += num[i];
			da += d + 1;
		}
	}
	else
	{
		for (int i = 0; i < m - 1; i++)da += num[i];
		da += d;
	}
	cout << da;
}

如果輸入的是字符串,Java的split函數可以幫大忙。

比如

給你一個按 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

class Solution 
{
    public int dayOfYear(String date)
    {
        String[] s=date.split("-");
        int y=Integer.parseInt(s[0]),m=Integer.parseInt(s[1]),d=Integer.parseInt(s[2]),da = 0;
        int [] num={31,28,31,30,31,30,31,31,30,31,30,31};
        if(y%4==0&&y%100!=0||y%400==0)
        {
            if(m<=2)
            {
                for(int i=0;i<m-1;i++)da+=num[i];
                da+=d;
            }
            else
            {
                for(int i=0;i<m-1;i++)da+=num[i];
                da+=d+1;
            }
        }
        else
        {
            for(int i=0;i<m-1;i++)da+=num[i];
            da+=d;
        }
        return da;
    }
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章