完全日期(蓝桥杯)

文章目录

完全日期

题目描述

本题为填空题,只需要算出结果后,在代码中使用输出语句将所填结果输出即可。

如果一个日期中年月日的各位数字之和是完全平方数,则称为一个完全日期。

例如:2021 年 6 月 5 日的各位数字之和为 2 + 0 + 2 + 1 + 6 + 5 = 162+0+2+1+6+5=16,而 16 是一个完全平方数,它是 44 的平方。所以 20212021 年 6 月 5 日是一个完全日期。

例如:2021年 6 月 23 日的各位数字之和为 2 + 0 + 2 + 1 + 6 + 2 + 3 = 162+0+2+1+6+2+3=16,是一个完全平方数。所以 2021 年 6 月 23 日也是一个完全日期。

请问,从 2001 年 1月 1日到 2021年 12 月 31日中,一共有多少个完全日期?

模拟

cpp 复制代码
// 导入必要的标准库
#include <bits/stdc++.h>
using namespace std;

// 预定义每个月的天数,其中二月默认为28天,闰年时会修改
int months[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};

// 定义一个检查函数,用来判断某个日期的年月日数字和是否为完全平方数
bool check(int n)
{
    int sum=0; // 定义一个变量来存储数字和
    // 使用循环来计算年月日所有数字的和
    while(n)
    {
        sum+=n%10; // 计算当前最低位的数字,并加到和中
        n/=10; // 将数字右移一位,即去掉已经处理的最低位
    }
    // 从1到8遍历所有可能的平方数(因为数字和不会超过两位数的完全平方数)
    for(int i=1;i<=8;i++)
    {
        // 如果i的平方等于数字和,则返回true,表示这是一个完全日期
        if(pow(i,2)==sum)
            return true;
    }
    // 如果所有的平方数都不匹配,则返回false
    return false;
}

// 主函数
int main()
{
    int ans=0; // 用于存储完全日期的总数
    // 遍历2001年到2021年所有的年份
    for(int i=2001;i<=2021;i++)
    {
        // 判断当前年份是否为闰年,并设置二月的天数
        if(i%4==0&&i%100!=0||i%400==0)
            months[2]=29;
        else
            months[2]=28;
        // 遍历每个月
        for(int j=1;j<=12;j++)
        {
            // 遍历每天
            for(int k=1;k<=months[j];k++)
            {
                // 生成当前日期的数字形式,如20210605
                int num=i*10000+j*100+k;
                // 调用check函数检查当前日期
                if(check(num))
                    ans++; // 如果是完全日期,计数器加1
            }
        }
    }
    // 输出完全日期的总数
    cout<<ans;
    return 0;
}

代码的主要逻辑是遍历指定日期范围内的每一天,将年月日组成一个整数,并计算这个整数每位数字的和,然后检查这个和是否是1到8中某个数的平方,如果是,则将该日期视为"完全日期",并对完全日期的总数进行计数。最后,输出在指定日期范围内的完全日期总数。

相关推荐
Yupureki13 分钟前
《Linux网络编程》1.网络基础
linux·运维·服务器·c语言·网络·c++
十五年专注C++开发22 分钟前
银河麒麟V10系统安装vcpkg的方法
c++·cmake·vcpkg
未来之窗软件服务25 分钟前
SenseVoicecpp ggml-webgpu大模型[AI人工智能(七十五)]—东方仙盟
c++·人工智能·算法·仙盟创梦ide·东方仙盟
寂柒29 分钟前
C++——堆
开发语言·c++
郝学胜-神的一滴33 分钟前
解锁CS数据存储的核心逻辑:从结构选择到表单设计的全解析
linux·服务器·数据库·c++·后端·oracle
Q741_1471 小时前
每日一题 力扣 3418. 机器人可以获得的最大金币数 力扣 215. 数组中的第K个最大元素 动态规划 TopK问题 C++ 题解
c++·算法·leetcode·动态规划·topk
haibindev1 小时前
写了10年代码的人,在AI编程时代反而最值钱
c++·ai编程·claude
寻寻觅觅☆1 小时前
东华OJ-基础题-31-素数(C++)
开发语言·c++·算法
Mr_Xuhhh1 小时前
C++算法刷题:排序子序列、削减整数、最长上升子序列(二)题解
开发语言·c++·算法
tankeven1 小时前
HJ157 剪纸游戏
c++·算法