HHUOJ_1337: 18岁生日
来源:互联网 发布:矩阵式组织结构特点 编辑:程序博客网 时间:2024/05/01 00:00
HHUOJ_1337: 18岁生日
题目描述
小明的18岁生日就要到了,他当然很开心,可是他突然想到一个问题,是不是每个人从出生开始,到达18岁生日时所经过的天数都是一样的呢?似乎并不全都是这样,所以他想请你帮忙计算一下他和他的几个朋友从出生到达18岁生日所经过的总天数,让他好来比较一下。
输入
输入的第一行是一个数T,后面T行每行有一个日期,格式是YYYY-MM-DD。如我的生日是1988-03-07。
输出
T行,每行一个数,表示此人从出生到18岁生日所经过的天数。如果这个人没有18岁生日,就输出-1。
样例输入
11988-03-07
样例输出
6574
思路
刚拿到这个题总有着似曾相似的感觉,第一反应就是判断闰年(废话…),然后就想肯定是在闰年的2.29动手脚(还是废话…)
题目看着看着突然灵光闪现,如果这个人没有18岁生日,就输出-1。
,是不是还要判断这个人到现在为止有没有十八岁啊?然后就在想怎么获得现在的时间…百思不得其姐,查了下才发现“没有18岁生日”的意思是这个人在闰年的2.29日出生啊…
此外还要注意:
1. 出生的那一年如果是闰年,是在2.29前面还是后面?
2. 十八岁那年如果是闰年,是在2.29前面还是后面?
代码
#include <iostream>using namespace std;int isLeapYear(int n){//判断闰年 if((n%4==0 && n%100!=0) || n%400==0){ return 1; } return 0;}int main(){ int t; cin>>t; while(t--){ int y, m, d; int cnt = 0; int py = 0;//偏移量 scanf("%d-%d-%d", &y, &m, &d); if(isLeapYear(y) && m==2 && d==29){ //这个人四年(非绝对)过一次生日,所以没有十八岁 cout<<-1<<endl; continue; } if(isLeapYear(y) && m>=3){//生闰年3月及以后,天数后面会多算一天 py = -1; } if(isLeapYear(y+18) && m<3){//18岁生日在3月之前(不必考虑2.29,因为在前面已经处理过了),出生那一年的天数与18岁这一年的天数相等,不影响结果 py = 0; } if(isLeapYear(y+18) && m>=3){//18岁生日在3月及以后,出生时一定是非闰年,后面循环是加的出生这一年的天数,与18岁这一年的天数相比少了一天,因此需要+1 py = 1; } for(int i=0; i<18; i++){ int yy = y+i; if(isLeapYear(yy)){ cnt += 366; }else { cnt+= 365; } } cout<<cnt+py<<endl; } return 0;}
阅读全文
0 0
- HHUOJ_1337: 18岁生日
- hdu1201 18岁生日
- hdu_1201:18岁生日
- 18岁的生日
- HDU1201:18岁生日
- 18岁生日
- 18岁生日
- [ACM]18岁生日
- 18岁生日
- HDU1201 18岁生日
- 18岁生日
- 18岁生日
- hdu_1201 18岁生日
- 18,20岁生日
- hdu1201 18岁生日
- hdu1201-18岁生日
- hdu1201--18岁生日
- 18岁生日
- leetcode: 59. Spiral Matrix II
- hdoj 2036 改革春风吹满地
- 使用poi导出Excel
- QPS、RT、PV、UV之间的关系
- 【云星数据---Apache Flink实战系列(精品版)】:Apache Flink高级特性与高级应用003-Flink的内存管理003
- HHUOJ_1337: 18岁生日
- ArrayList
- quartz定时器实现
- 在 JNI 编程中避免内存泄漏
- codeforces 888G Xor-MST Sollin算法求最小生成树,0-1异或True
- leetcode: 60. Permutation Sequence
- MATLAB(ofdm注水算法odfmwaterfilling)
- 文章标题
- DS Simulia XFlow 2017 官方中文版下载附安装教程