博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HDU 1201
阅读量:6077 次
发布时间:2019-06-20

本文共 1128 字,大约阅读时间需要 3 分钟。

18岁生日

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 18353    Accepted Submission(s): 5804


Problem Description
Gardon的18岁生日就要到了,他当然非常开心,但是他突然想到一个问题,是不是每一个人从出生開始,到达18岁生日时所经过的天数都是一样的呢?似乎并不全都是这样,所以他想请你帮忙计算一下他和他的几个朋友从出生到达18岁生日所经过的总天数,让他好来比較一下。
 

Input
一个数T,后面T行每行有一个日期,格式是YYYY-MM-DD。如我的生日是1988-03-07。
 

Output
T行,每行一个数,表示此人从出生到18岁生日所经过的天数。假设这个人没有18岁生日,就输出-1。
 

Sample Input
 
1 1988-03-07
 

Sample Output
 
6574
 

#include
int leap(int Y){ if(Y%4==0&&Y%100!=0||Y%400==0) return 1; else return 0;}int main() { int i,T; int Y,M,D; int Date; scanf("%d",&T); while(T--) { Date=18*365; scanf("%d-%d-%d",&Y,&M,&D); if(!leap(Y+18)&&M==2&&D==29) { printf("-1\n");continue; } if(leap(Y)&&(M<2||M==2)&&D<=28) Date++;//此处有逻辑问题,不加括号会出现错误 //if(leap(Y)&&M==2&&D==29&&leap(Y+18)) Date++; //if(M>2&&leap(Y+18)) Date++; if(leap(Y+18)&&M>2||M==2&&D==29) Date++; for(i=Y+1;i<=Y+17;i++) { if(leap(i)) Date++; } printf("%d\n",Date); } return 0;}

转载地址:http://dfxgx.baihongyu.com/

你可能感兴趣的文章
就《在企业中发起和推广DevOps》的问答
查看>>
促进大会上的交流
查看>>
SRE系列教程 | 基于时间序列数据的监控实践
查看>>
WIFI 万能钥匙万玉权:团队之中要有跨三界之外的“闲人”
查看>>
Android -- 加载大图片的方法
查看>>
Blend 3状态为空的解决方法
查看>>
什么样的企业可以称之为初创企业?
查看>>
安全厂商间真的能“数据共享,协同合作”吗
查看>>
那些优秀程序员身上的共同特质
查看>>
Python爬虫之BeautifulSoup
查看>>
《HTML 5与CSS 3权威指南(第3版·下册)》——第20章 使用选择器在页面中插入内容...
查看>>
空中鼠标算法原理讨论
查看>>
UITableView整理
查看>>
Akka笔记之Actor简介
查看>>
Android 使用SystemBarTint设置状态栏颜色
查看>>
GreenPlum vs MonetDB case
查看>>
JVM源码分析之SystemGC完全解读
查看>>
盘点 PHP 和 ASP.NET 的10大对比!
查看>>
Systemtap examples, Identifying Contended User-Space Locks
查看>>
PostgreSQL Daily Maintenance - cluster table
查看>>