蓝桥杯--跑步计划

问题描述

小蓝计划在某天的日期中出现 11 时跑 55 千米,否则只跑 11 千米。注意日期中出现 11 不仅指年月日也指星期。

请问按照小蓝的计划,20232023 年小蓝总共会跑步锻炼多少千米?例如,55 月 11 日、11 月 1313 日、1111 月 55 日、44 月 33 日 (星期一) 小蓝会跑 55 千米,而 55 月 2323 日小蓝会跑 11 千米 (示例日期均为 2023 年)


思路: 知道2023年是平年,四月三日是星期一 , 求出到四月三日一共的天数,再求七天的余数. 根据这个余数可以判断某天是否为星期一

所以,大致思路如下

cpp 复制代码
#include <iostream>
using namespace std;
int DAY(int month, int day)//由月和日,直接求天数
{
    int add = 0;
    int M[] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };
    for (int i = 0; i < month; i++)
    {
        add += M[i ];
    }
    add += day;
    return add;
}
int main()
{
    int b = DAY(4, 3) % 7;//已知(4,3)为星期一,求余数
    int M[] = { 31,28,31,30,31,30,31,31,30,31,30,31 };
    int day;
    int c = 0;//重复的
    int d = 0;//all 1
    int e = 0;//all 2 
    for ( int x = 1; x <=12; x++)
    {
        for (int y = 1; y <=M[x-1]; y++)
        {
            if (x == 1 || x/10==1 || y / 10 == 1 || y % 10 == 1)
            {
                d++;//月,日总数
                day = DAY(x, y);
                if (day % 7 == b)                        
                {
                    c++;//重复的
                }
            }
        }
    }
    for (int i = 1; i <= 365; i++)//求星期一总数
    {
        if (i  % 7 == b)
        {
            e++;
        }
    }
    int f = d - c + e;//求总和
    f = f * 5 + 365 - f;
    cout << f<< endl;
    return 0;
}
相关推荐
旖-旎2 分钟前
《LeetCode 695 岛屿的最大面积 FloodFill DFS 解法》
c++·算法·力扣·深度优先遍历·floodfill
森G21 分钟前
61、信号与槽机制在 TCP 编程中的应用---------网络编程
网络·c++·qt·网络协议·tcp/ip
syagain_zsx33 分钟前
STL 之 vector 讲练结合
c++·算法
牛油果子哥q1 小时前
STL set与map底层精讲,红黑树适配原理、有序去重特性、迭代器遍历、API实战与面试核心考点全解
开发语言·数据结构·c++·面试
奇妙方程式2 小时前
2026年第九届GXCPC广西大学生程序设计大赛(热身赛)题解
c++·编程比赛·编程竞赛·gxcpc
Tian_Hang2 小时前
C++原型模式(Protype)
开发语言·c++·算法
FL16238631293 小时前
[cmake]基于C++使用纯opencv部署ppocrv5v6的onnx模型
开发语言·c++·opencv
玖玥拾3 小时前
C/C++ 数据结构(六)链表迭代器与底层
c语言·数据结构·c++·链表·stl库
牛油果子哥q4 小时前
AVL平衡树与红黑树深度精讲对比,平衡因子、四大旋转原理、着色规则、平衡策略、性能差异与面试手撕全解
数据结构·c++·面试
汉克老师4 小时前
GESP7级C++考试语法知识(二、指数函数(3、综合练习)
c++·算法·数学建模·指数函数·gesp7级·复利