蓝桥杯:日期统计讲解(C++)

日期统计

本题来自于:2023年十四届省赛大学B组真题

主要考察:暴力。

代码放在下面,代码中重要的细节全都写了注释,非常清晰明了:

cpp 复制代码
#include <bits/stdc++.h>  //万能头文件
using namespace std;

int main() {
    int array[100] = {
        5, 6, 8, 6, 9, 1, 6, 1, 2, 4, 9, 1, 9, 8, 2, 3, 6, 4, 7, 7,
        5, 9, 5, 0, 3, 8, 7, 5, 8, 1, 5, 8, 6, 1, 8, 3, 0, 3, 7, 9,
        2, 7, 0, 5, 8, 8, 5, 7, 0, 9, 9, 1, 9, 4, 4, 6, 8, 6, 3, 3,
        8, 5, 1, 6, 3, 4, 6, 7, 0, 7, 8, 2, 7, 6, 8, 9, 5, 6, 5, 6,
        1, 4, 0, 1, 0, 0, 9, 4, 8, 0, 9, 1, 2, 8, 5, 0, 2, 5, 3, 3
    };  //先按题目要求放到数组中

    int daysInMonth[13] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
    //2023年每月的天数,电脑上自带日期,可以随便查   ,0索引不用,从1索引开始用,代表1月份
    int ans = 0;  //记录符合条件的日期

    for (int month = 1; month <= 12; ++month) {  //2023年已经确定,从月份开始
        for (int day = 1; day <= daysInMonth[month]; ++day) {//每个月的天数
            int dateSeq[8] = {2, 0, 2, 3, month / 10, month % 10, day / 10, day % 10};//用数组保存长度为8的日期
            int k = 0;   
            for (int i = 0; i < 100; ++i) {//i < 100 ,代表要开始遍历数组了(arr数组)
                if (array[i] == dateSeq[k]) {
                    ++k;
                    if (k == 8) {
                        ans++;
                        break;
                    }
                }
            }
        }
    }
    cout << ans;  //把结果输出
    return 0;
}
相关推荐
愚润求学12 分钟前
【动态规划】专题完结,题单汇总
算法·leetcode·动态规划
MOONICK21 分钟前
数据结构——哈希表
数据结构·哈希算法·散列表
林太白24 分钟前
跟着TRAE SOLO学习两大搜索
前端·算法
爱凤的小光34 分钟前
图漾GM461-E1相机专栏
c++
biter down1 小时前
c语言18:结构体位段联合体
c语言·开发语言
ghie90901 小时前
图像去雾算法详解与MATLAB实现
开发语言·算法·matlab
云泽8081 小时前
从三路快排到内省排序:探索工业级排序算法的演进
算法·排序算法
qwepoilkjasd1 小时前
C++智能指针介绍
c++
weixin_468466851 小时前
遗传算法求解TSP旅行商问题python代码实战
python·算法·算法优化·遗传算法·旅行商问题·智能优化·np问题
·白小白2 小时前
力扣(LeetCode) ——43.字符串相乘(C++)
c++·leetcode