NYOJ 312 20岁生日
来源:互联网 发布:teackpad Windows 编辑:程序博客网 时间:2024/05/17 00:02
20岁生日
时间限制:1000 ms | 内存限制:65535 KB
难度:1
- 描述
- 路过这的20岁生日就要到了,他当然很开心,可是他突然想到一个问题,是不是每个人从出生开始,到达20岁生日时所经过的天数都是一样的呢?似乎并不全都是这样,所以他想请你帮忙计算一下他和他的几个朋友从出生到达20岁生日所经过的总天数,让他好来比较一下。
- 输入
- 一个数T,后面T行每行有一个日期,格式是YYYY-MM-DD。如我的生日是1988-03-07。
- 输出
- T行,每行一个数,表示此人从出生到20岁生日所经过的天数。如果这个人没有20岁生日,就输出-1。
- 样例输入
11988-03-07
- 样例输出
7305
- 来源
- hdu
- 上传者
路过这
/***类型:入门级题目**题目来源:NYOJ 312**时间:2017/7/24**解决方案:*/#include<stdio.h>int main(){int T,i,j;scanf("%d",&T);while(T--){int year,month,day;scanf("%d-%d-%d",&year,&month,&day);int a[13] = {0,31,28,31,30,31,30,31,31,30,31,30,31};int sum1,sum2,sum3,flag,flag1;sum1 = sum2 = sum3 = 0;for(i=year+1; i<year+20;i++){if(i%4==0&&i%100!=0||i%400==0){sum1 = sum1 + 366;}else{sum1 = sum1 + 365;}}//出生那年余下的天数if(year%4==0&&year%100!=0||year%400==0){a[2] = 29; flag = 1;}for(i=month+1;i<13;i++){sum2 = sum2 + a[i]; }sum2 = sum2 + a[month] - day;//20周岁那年多出的天数 if((year+20)%4==0&&(year+20)%100!=0||(year+20)%400==0){a[2] = 29; flag1 = 1;}else{a[2] = 28;flag1 = 0;}for(i=0;i<month;i++){sum3 = sum3 + a[i];} sum3 = sum3 + day;if(flag==1&&flag1==0&&month==2&&day==29){printf("-1\n");}else{printf("%d\n",sum1+sum2+sum3);}} return 0;}//闰年29天 平年28天 并注意没有20岁生日的条件
阅读全文
0 0
- NYOJ 312 20岁生日
- NYOJ 312 20岁生日
- nyoj-312-20岁生日
- NYOJ 312 20岁生日
- NYOJ 312-20岁生日
- nyoj 312 20岁生日
- NYOJ 312 20岁生日
- NYOJ 312 20岁生日
- NYOJ-20岁生日
- NYOJ 312题 20岁生日
- nyoj 312-20岁的生日
- 20岁生日 nyoj 312(闰年算法)
- NYOJ-312-20岁生日-2013年08月17日08:42:42
- 312 20岁生日
- NYOJ zb的生日
- nyoj zb的生日
- NYOJ zb的生日
- NYOJ zb的生日
- 化学品问题 oj137
- 当U盘启动时,出现grub>如果将启动项引导到硬盘?
- (一)maven 安装配置
- 算法学习资料
- Redis五种数据类型介绍
- NYOJ 312 20岁生日
- Java高级工程师常见面试题
- ibatis 日常问题总结
- hibernate学习笔记三
- js练习之个人信息的输入和显示
- containsKey方法——判断是否包含指定的键名
- 那些年,让我们一起头疼的异常!
- nodejs debug 模块使用
- Python数据挖掘的一些前期准备