蓝桥杯:1.特殊日期(Java)

题目描述

对于一个日期,我们可以计算出年份的各个数位上的数字之和,也可以分别计算月和日的各位数字之和。

请问从1900年1月1日至9999年12月31日,总共有多少天,年份的数位数字之和等于月的数位数字之和加日的数位数字之和。

例如,2022年11月13日满足要求,因为2+0+2+2=(1+1)+(1+3)。

请提交满足条件的日期的总数量。

答案提交:

这是---道结果填空的题,你只需要算出结果后提交即可。

本题的结果为一个整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。

输出:

70910

代码实现:

java 复制代码
public class Main{
    public static void main(String[] args) {
        int cnt = 0;
        //不同月份的天数不同
        int[] days = new int[]{0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
        for (int i = 1900; i <= 9999; i++) {
            //年:i
            //判断是否是闰年:(能被4整除但不能被100整除)或者(能被400被整除)
            if ((i % 4 == 0 && i % 100 != 0) || (i % 400 == 0)) {
                days[2] = 29;//如果是润年:二月份为29天
            } else {
                days[2] = 28;
            }
            for (int j = 1; j <= 12; j++) {
                //月:j
                for (int k = 1; k <= days[j]; k++) {
                    //日:k
                    //计数:年份数位之和 是否等于 月份和天数的数位之和
                    if (sum(i) == sum(j) + sum(k)) {
                        cnt++;
                    }
                }//k
            }//j
        }//i
        //输出
        System.out.println(cnt);
    }

    /**
     * 计算任意一个整数的数位之和
     *
     * @param n 整数
     * @return 返回数位之和
     */
    public static int sum(int n) {
        int res = 0;//结果
        while (n != 0) {//原数为0时,跳出循环
            res += n % 10;//取个数数字累加
            n = n / 10;//原数除10
        }
        return res;
    }
}
相关推荐
随意起个昵称3 小时前
区间dp-基础题目1(石子合并)
算法·动态规划
吞下星星的少年·-·3 小时前
线段树模板
算法
橙淮3 小时前
并发编程(六)
java·jvm
段一凡-华北理工大学3 小时前
2026 高炉炼铁智能化技术全景与演进路径~系列文章11:演进路径与行业未来
大数据·网络·人工智能·算法·工业智能体·高炉炼铁智能化
拽着尾巴的鱼儿3 小时前
springboot openfeign 自定义feign 接口重试机制
java·spring boot·后端
白露与泡影3 小时前
2026大厂Java面试题大全!牛客网最新版
java·开发语言
叶小鸡4 小时前
小鸡玩算法-力扣HOT100-多维动态规划
算法·leetcode·动态规划
星马梦缘4 小时前
aaaaa
数据结构·c++·算法
EntyIU4 小时前
JVM内存与GC笔记
java·jvm·笔记
XS0301064 小时前
并发编程 六
java·后端