Problem I: 函数---判断某年某月某日是这一年中的第几天
2016-04-04 23:42
323 查看
Problem I: 函数---判断某年某月某日是这一年中的第几天
Time Limit: 1 Sec Memory Limit:128 MB
Submit: 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; else cout<<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; } } }
相关文章推荐
- Java多线程——多线程的基本概念和使用
- Github前端项目排名
- django之创建第6个项目-过滤器
- monkey事件类命令2
- 密码学应用(DES,AES, MD5, SHA1, RSA, Salt, Pkcs8)
- 2016第14周一
- Maven debug异常:Source not found.
- centos7下安装telnet服务器
- Problem H: 今年第几天?
- MaterialDesign
- 机器学习之K-近邻算法
- shell文本处理
- Problem G: 函数---判断日期(年月日)是否合法
- Android 学习笔记(9)—— ListView
- @Helper辅助方法和@functions自定义函数
- HTML中使用JavaScript
- Minigui3在海思Hi3520D/Hi3531平台上运行
- 面试题21 包含min函数的栈
- spring培训第一讲-ioc实现原理源码解析
- boostrap中scrollspy结合affix、以及affix的滚动与定位