Java特殊日期

本文提供了两种Java编程解决方案,使用LocalDate类和枚举法,计算从1900年1月1日至9999年12月31日期间,数位和相等的日期总数。
摘要由CSDN通过智能技术生成

问题描述
对于一个日期,我们可以计算出年份的各个数位上的数字之和,也可以分别计算月和日的各位数字之和。请问从1900年1月1日至9999年12月31日,总共有多少天,年份的数位数字之和等于月的数位数字之和加日的数位数字之和。
例如,2022年11月13日满足要求,因为2+0+2+2=(1+1)+(1 +3)。
请提交满足条件的日期的总数量
答案提交
这是一道结果填空的题,你只需要算出结果后提交即可。本题的结果为一个整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。

题解1:使用LocalDate类

import java.util.Scanner;
import java.time.LocalDate;
// 1:无需package
// 2: 类名必须Main, 不可修改

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        //在此输入您的代码...
        LocalDate begin = LocalDate.parse("1900-01-01");
        LocalDate end = LocalDate.parse("9999-12-31");
        long count = 0;
        while(!(begin.equals(end))) {
          if(judge(begin))count++;
          begin = begin.plusDays(1);
        }
        System.out.print(count);
        scan.close();
    }
    public static boolean judge(LocalDate ld) {
    int year = ld.getYear();
    int month = ld.getMonthValue();    
    int day = ld.getDayOfMonth();
    int sum1 = 0,sum2 = 0;
    while(year != 0) {
      sum1 += year % 10;
      year /= 10;
    }
    while(month != 0) {
      sum2 += month % 10;
      month /= 10;
    }
    while(day != 0) {
      sum2 += day % 10;
      day /= 10;
    }
    if(sum1 == sum2) return true;
    return false;
  }
}

 题解2:不用LocalDate类

public class Main {
	public static void main(String[] args) {
		int[] days1 = {31,28,31,30,31,30,31,31,30,31,30,31};
		int[] days2 = {31,29,31,30,31,30,31,31,30,31,30,31};
		long count = 0;
		for(int i = 1900;i <= 9999;i++) {
			for(int j = 1;j <= 12;j++) {
				if((i % 400 == 0)||(i % 4 == 0 &&i % 100 != 0)) {
					for(int k1 = 1;k1 <= days2[j - 1];k1++) {
						if(Main.forSum(i) == Main.forSum(j)+Main.forSum(k1)) count++;
					}
				}else {
					for(int k2 = 1;k2 <= days1[j - 1];k2++) {
						if(Main.forSum(i) == Main.forSum(j)+Main.forSum(k2)) count++;
					}
				}
			}
			
		}
		System.out.print(count);
	}
	public static int forSum(int x) {
		int sum = 0;
		while(x != 0) {
			sum += x % 10;
			x /= 10;
		}
		return sum;
	}
}

两个题解均使用枚举法。 

  • 5
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值