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

本文介绍了一种方法,通过用户输入的年、月、日,判断并计算出该日期是一年中的第几天。涉及闰年判断及各月份天数累加的详细逻辑。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public static void main(String[] args) {
Scanner scan = new Scanner(System.in);
		System.out.println("输入年份:");
		int year = scan.nextInt();
		System.out.println("输入月份:");
		int month = scan.nextInt();
		System.out.println("输入日期:");
		int day = scan.nextInt();
		//判断是否是闰年
		//GregorianCalendar:判断年份是否是闰年的方法
		GregorianCalendar gre = new GregorianCalendar();
		boolean isLeapYear=gre.isLeapYear(year);//返回true:是闰年,false:不是闰年
		
		int ap=isLeapYear?29:28;//判断2月份的天数
		int days=0;
		switch (month) {
		case 1:
			days=day;
			break;
		case 2:
			days=31+day;
			break;
		case 3:
			days=31+ap+day;
			break;
		case 4:
			days=31+ap+31+day;
			break;
		case 5:
			days=31+ap+31+30+day;
			break;
		case 6:
			days=31+ap+31+30+31+day;
			break;
		case 7:
			days=31+ap+31+30+31+30+day;
			break;
		case 8:
			days=31+ap+31+30+31+30+31+day;
			break;
		case 9:
			days=31+ap+31+30+31+30+31+31+day;
			break;
		case 10:
			days=31+ap+31+30+31+30+31+31+30+day;
			break;
		case 11:
			days=31+ap+31+30+31+30+31+31+30+31+day;
			break;
		case 12:
			days=31+ap+31+30+31+30+31+31+30+31+30+day;
			break;
 
		default:
			System.out.println("月份输入错误");
			break;
		}
		System.out.println("这一天是这一年的第"+days+"天");
}
 
}
public class asgasaf {
    /**
     * 输入某年某月某日,判断这一天是这一年的第几天?
     * 
     */
    public static void main(String[] args) {
        int year;
        int mouth;
        int day=0;
        int days;
        //累计天数
        int d=0;
        int e = 0;
        Scanner scanner = new Scanner(System.in);
        do {
            System.out.println("输入年:");
            year = scanner.nextInt();
            System.out.println("输入月:");
            mouth = scanner.nextInt();
            System.out.println("输入日:");
            days = scanner.nextInt();
            if (mouth < 0 || mouth > 12 || days < 0 || days > 31) {
                System.out.println("input error!");
                e = 1;
            }
        } while (e == 1);
        for (int i = 1; i <mouth; i++) {
            switch (i) {
            case 1:
            case 3:
            case 5:
            case 7:
            case 8:
            case 10:
            case 12: {
                day = 31;
                break;
            }
            case 4:
            case 6:
            case 9:
            case 11: {
                day = 30;
                break;
            }
            case 2: {
                /**
                 * 闰年:①:非整百年数除以4,无余为闰,有余为平;②整百年数除以400,无余为闰有余平
                 * 二月:平年28天、闰年29天
                 */
                if ((year % 100 !=0 &&year % 4 == 0) || (year % 100 == 0 && year%400==0)) {
                    day = 29;
                } else {
                    day = 28;
                }
            }
            default:
                break;
            }
            d+=day;
        }
        System.out.println("这是"+year+"年的"+(d+days)+"天");
    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值