對於要求輸入的是整形的題即可用下面的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;
}
}