Problem I: 函數---判斷某年某月某日是這一年中的第幾天
Time Limit: 1 Sec??Memory Limit: 128 MBSubmit: 457??Solved: 194
Description
在主程序(main)中輸入某年某月某日,例如2012 9 18(年月日之間用空格隔開), 調用函數dayth來得到某年某月某日是這一年中是第幾天。????
注意 在利用dayth函數前要調用isValid_date函數來判斷日期是合法的。
dayth函數和isValid_date函數聲明如下:
int isValid_date(int year,int month,int day); //判斷日期(年月日)是否合法的函數聲明,如果日期合法返回1,如果不合法返回0
int dayth(int year,int month,int day); //獲取日期(年月日)是本年中的第幾天的函數聲明
在以下程序的基礎上,添加isValid_date函數和dayth函數的定義,使程序能夠正確執行。
提交時,只需要提交isValid_date函數和dayth函數的定義代碼即可。
#include <iostream>
using namespace std;
int isValid_date(int year,int month,int day); //判斷日期(年月日)是否合法的函數聲明,如果日期合法返回1,如果不合法返回0
int dayth(int year,int month,int day); //獲取日期(年月日)是本年中的第幾天的函數聲明
int main()
{
? int y,m,d; //定義3個變量分別來存放輸入的年、月、日
? cin>>y>>m>>d;
? if(isValid_date(y,m,d) ==0)
???? cout<<"not valid"<<endl;
? else
???? cout<<dayth(y,m,d)<<endl;
? return 0;
}
Input
一個日期(年 月 日)
Output
如果該日期和法則輸出該日期是本年中的第幾天,如果該日期不合法輸出提示信息
例如 輸入2002 3 1 輸出?60??????????????????? 輸入2008 2 30 輸出not valid
Sample Input
2002 3 1
Sample Output
60
HINT
#include <iostream>
using namespace std; int isValid_date(int year,int month,int day); //判斷日期(年月日)是否合法的函數聲明,如果日期合法返回1,如果不合法返回0 int dayth(int year,int month,int day); //獲取日期(年月日)是本年中的第幾天的函數聲明 int main()
{ int y,m,d; //定義3個變量分別來存放輸入的年、月、日 cin>>y>>m>>d; if(isValid_date(y,m,d)==0) cout<<"not valid"<<endl; elsecout<<dayth(y,m,d)<<endl; return 0;
}
int isValid_date(int year,int month,int day)
{ if((year%4==0||year%100!=0)&&(year%400==0)) { if(month>12||month<1) return 0; if((month==2&&(day>29||day<1))) return 0; if((month==1||month==3||month==5||month==7||month==8||month==10||month==12)&&(day>31||day<1)) return 0; if((month==4||month==6||month==9||month==11)&&(day>30||day<1)) return 0; return 1; } else{ if(month>12||month<1) return 0; if((month==2&&(day>28||day<1))) return 0; if((month==1||month==3||month==5||month==7||month==8||month==10||month==12)&&(day>31||day<1)) return 0; if((month==4||month==6||month==9||month==11)&&(day>30||day<1)) return 0; return 1; }
}
int dayth(int year,int month,int day) { int a[12]={31,28,31,30,31,30,31,31,30,31,30,31},sum=0; for(int i=0;i<month-1;i++) { sum+=a[i]; } if(month>=1&&month<=12) { if((month==2)&&(day>=1&&day<=28)) { sum=sum+day; if(((year%4==0&&year%100!=0)||(year%400==0))&&(month>2)) return sum+1; else return sum; } if((month==1||month==3||month==5||month==7||month==8||month==10||month==12)&&(day<=31&&day>=1)) { sum=sum+day; if(((year%4==0&&year%100!=0)||(year%400==0))&&(month>2)) return sum+1; else return sum; } if((month==4||month==6||month==9||month==11)&&(day<=30&&day>=1)) { sum=sum+day; if(((year%4==0&&year%100!=0)||(year%400==0))&&(month>2)) return sum+1; else return sum; } } }