华为机试---计算日期到天数转换

来源:互联网 发布:wap论坛源码 编辑:程序博客网 时间:2024/05/01 13:54

题目描述

根据输入的日期,计算是这一年的第几天。。

详细描述:

输入某年某月某日,判断这一天是这一年的第几天?。 


输入描述:

输入三行,分别是年,月,日


输出描述:

成功:返回outDay输出计算后的第几天;失败:返回-1


输入例子:
20121231

输出例子:
366


import java.util.Scanner;



public class Main {
public static void main(String[] args) {
Scanner scan = new Scanner(System.in);
while (scan.hasNext()) {
int year = scan.nextInt();
int month = scan.nextInt();
int day = scan.nextInt();
System.out.println(converDateToDay(year, month, day));
}//endwhile
scan.close();
}
private static int converDateToDay(int year , int month , int day){
int to_day = 0;
if(!isLegalInput(year, month, day)){
to_day = -1;
}else{
//闰年二月29天,平年二月28天
int[] leap_year_month = {31,29,31,30,31,30,31,31,30,31,30,31};
int[] not_leap_year_month = {31,28,31,30,31,30,31,31,30,31,30,31};
if(isLeapYear(year)){
for(int i = 0 ; i < month - 1 ; i++){
to_day += leap_year_month[i];
}
to_day += day;
}else{
for(int i = 0 ; i < month - 1 ; i++){
to_day += not_leap_year_month[i];
}
to_day += day;
}
}
return to_day;
}
/**
* 判断输入日期是否合法
* */
private static boolean isLegalInput(int year , int month , int day){
boolean flag = true;
//判断年份
if(year < 0){
return false;
}
//判断月份
if(month <= 0 || month > 12){
return false;
}
//判断day,最大31天,暂不加更加精细的闰平年,月份的具体判断
if(day > 31){
return false;
}
return flag;
}
/**
* 判断年份是否是闰年
* */
    private static boolean isLeapYear(int year){
    boolean flag = false;
    if((year % 4 == 0 && year % 100 != 0 )|| year % 400 == 0){
    flag = true;
    }
    return flag;
    }
}



0 0