首页 > 其他分享 >HDOJ1210 18岁生日

HDOJ1210 18岁生日

时间:2023-02-20 10:32:33浏览次数:31  
标签:int 18 sumDay HDOJ1210 year 生日 十八岁


18岁生日


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


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


需要知道的:如何判断闰年;题目所讲的什么是没有十八岁生日。


判断闰年一般就是能整除4并且不能整除100,或者能整除400。


没有十八岁生日就是出生在2月29,但十八岁那年正好没2月29(也就十八岁那年不是闰年)




此外要是出生在2月28号之前,第一年和十八岁那年的天数是出生那年决定的。


在之后就是十八岁生日那年决定的,


import java.util.Scanner;

public class Main{
private static Scanner scanner;
public static void main(String[] args) {
scanner = new Scanner(System.in);
int cases = scanner.nextInt();
while(cases-->0){
String string = scanner.next();
String strings[] = string.split("-");
int year = Integer.parseInt(strings[0]);
int month = Integer.parseInt(strings[1]);
int day = Integer.parseInt(strings[2]);
// System.out.println(year+" "+month+" "+day);
if(month==2&&day==29){
if(!isLeepYear(year+18)){
System.out.println(-1);//木有十八岁升入
continue;
}
}
int sumDay = 0;
if(month<=2&&day<=28){//第一年和最后一年
if(isLeepYear(year)){
sumDay = 366;
}else {
sumDay = 365;
}
}else {
if(isLeepYear(year+18)){
sumDay = 366;
}else {
sumDay = 365;
}
}//中间部分
for (int i = year+1; i < year+18; i++) {
if(isLeepYear(i)){
sumDay += 366;
}else {
sumDay += 365;
}
}
System.out.println(sumDay);
}
}
public static boolean isLeepYear(int year){//判断闰年
if(year%4==0&&year%100!=0||year%400==0){
return true;
}
return false;
}
}



标签:int,18,sumDay,HDOJ1210,year,生日,十八岁
From: https://blog.51cto.com/u_15741949/6067741

相关文章

  • 代码随想录算法Day18 | 513.找树左下角的值 , 112. 路径总和 ,113.路径总和ii , 106.从中
     513.找树左下角的值题目链接:513.找树左下角的值-力扣(LeetCode)题目给定一个二叉树的根节点root,请找出该二叉树的 最底层 最左边 节点的值。假设二叉树中至少......
  • CF1188DE
    D.MakeEqual题意:给定\(n\)个正整数\(a_1,a_2,...,a_n\),每次操作可以给一个\(a_i\)加上\(2\)的一个非负整数次幂,问最少多少次使得全同。题解:很妙啊!感觉非常没有......
  • uni-app api:扫描二维码(hbuilderx 3.6.18)
    一,代码:<template><view><button@click="scanCode">扫码</button><text>扫码类型:{{scanType}}</text><text>扫码内容:{{result}}</text>......
  • 【JavaScript】18_面向对象,类与属性
    1、面向对象面向对象编程(OOP)程序是干嘛的?程序就是对现实世界的抽象(照片就是对人的抽象)对象是干嘛的?一个事物抽象到程序中后就变成了对象在程序的世界中,一切皆对象面向对象......
  • uni-app api:使用剪贴板进行复制粘贴(hbuilderx 3.6.18)
    一,代码:<template><view><inputclass="btn"style="background:#ffff00;"type="text"v-model="content"/><buttonclass="btn"@click="setCl......
  • uni-app api:拨打电话(hbuilderx 3.6.18)
    一,代码:<template><view><button@click="call">拨打电话</button></view></template><script>exportdefault{data(){......
  • 利用Quartus 18.0设计Nios II系统教程
    最后修改日期:2023/02/191.概要1.1.软件Quartus18.0PrimeStandard及内部工具1.2.电路板AlteraDE2-115开发板1.3.PLD器件信号FPGA:AlteraCycloneIVENo:E......
  • [PKUSC2018]神仙的游戏
    神仙的游戏设s的长度为len,那么当k<=\(\lfloor\frac{len}{2}\rfloor\)时,只需要s[1..k]=s[len-k+1...len]即可。也就是说我们要判断前缀的1与后缀的0是否对应。......
  • Functions2-18
    因为underscore本来就是为了充分发挥JavaScript的函数式编程特性,所以也提供了大量JavaScript本身没有的高阶函数。bind​​bind()​​有什么用?我们先看一个常见的错误用法:'u......
  • 线程18
    条件变量时构建在另一个锁上的同步原语,当需要线程关注特定的状态变化或事件发生时将使用这个锁。典型的用法是生产者与消费者问题,其中一个线程生产的数据提供给另外一个线程......