蓝桥杯每日真题 - 第15天

题目:(钟表)

题目描述(13届 C&C++ B组B题)

解题思路:

  1. 理解钟表指针的运动

    • 秒针每分钟转一圈,即每秒转6度。

    • 分针每小时转一圈,即每分钟转6度。

    • 时针每12小时转一圈,即每分钟转0.5度。

  2. 计算角度

    • 秒针的角度 S=6m(其中 m 是秒)。

    • 分针的角度 M=6f+0.1m(其中 f 是分)。

    • 时针的角度 H=30s+0.5f+0.0083m(其中 s 是小时)。

  3. 计算夹角

    • 分针和时针的夹角 A=∣H−M∣。

    • 分针和秒针的夹角 B=∣M−S∣。

  4. 条件判断

    • 需要满足 A=2B。
  5. 遍历时间

    • 从 s=0 到 s=6,ff 从 0 到 59,mm 从 0 到 59,检查每个时间点是否满足条件。

代码实现(C语言):

cs 复制代码
#include <stdio.h>
#include <stdlib.h>

int main()
{
    int h = 0, m = 0, s = 0; // 时、分、秒
    double A, B, H, M, S;    // A、B 表示题目中的夹角,H、M、S 表示时针、分针、秒针的度数

    while (h < 6) // 时针只需遍历 0~6
    {
        s++; // 秒针每秒加一
        if (s == 60) // 秒针转一圈
        {
            s = 0;
            m++;
        }
        if (m == 60) // 分针转一圈
        {
            m = 0;
            h++;
        }

        // 计算秒针、分针、时针当前的位置(以度数为单位)
        S = s * 6.0;                           // 秒针每秒走6度
        M = (m + s / 60.0) * 6.0;              // 分针每分钟走6度,并加上秒针带来的细微变化
        H = (h + m / 60.0 + s / 3600.0) * 30.0; // 时针每小时走30度,并加上分针和秒针带来的变化

        // 计算时针与分针的夹角 A
        A = (H > M) ? (H - M) : (M - H);
        if (A > 180) A = 360 - A; // 确保 A 在 [0, 180] 范围内

        // 计算分针与秒针的夹角 B
        B = (S > M) ? (S - M) : (M - S);
        if (B > 180) B = 360 - B; // 确保 B 在 [0, 180] 范围内

        // 判断是否满足 A = 2B
        if (A == 2 * B)
        {
            // 找到答案后直接跳出循环
            break;
        }
    }

    // 输出时、分、秒
    printf("%d %d %d\n", h, m, s);
    return 0;
}

得到运行结果:

代码分析:

变量说明

  • h, m, s:分别表示小时、分钟、秒的整数值。

  • H, M, S:分别表示时针、分针、秒针所指向的具体角度(度数)。

  • A, B:分别表示时针与分针的夹角、分针与秒针的夹角。

角度计算

  • 秒针的角度。秒针每秒钟走 6 度。

  • 分针的角度。分针每分钟走 6 度,且秒针的细微变化会影响分针的位置。

  • 时针的角度。时针每小时走 30 度,同时分针和秒针也会微调时针的位置。

夹角计算

  • 两个指针的夹角:是大角减小角,如果夹角大于 180 度,取补角。

  • 时针与分针夹角 A

  • 分针与秒针夹角 B

判断条件

  • 只需判断是否满足 ( A = 2B )。

循环终止

  • 当找到符合条件的时、分、秒时,用 break 终止循环,输出结果即可。

难度分析

⭐️⭐️⭐️

总结

这段代码通过模拟时钟的运行,计算出在一天中的某个时刻,时针和分针的夹角是分针和秒针夹角的两倍。这个问题考察了对时间的理解和指针运动的计算,以及如何将这些计算转化为代码实现。

相关推荐
最后一个bug7 分钟前
STM32MP1linux根文件系统目录作用
linux·c语言·arm开发·单片机·嵌入式硬件
林的快手11 分钟前
209.长度最小的子数组
java·数据结构·数据库·python·算法·leetcode
FeboReigns12 分钟前
C++简明教程(4)(Hello World)
c语言·c++
FeboReigns13 分钟前
C++简明教程(10)(初识类)
c语言·开发语言·c++
千天夜20 分钟前
多源多点路径规划:基于启发式动态生成树算法的实现
算法·机器学习·动态规划
从以前25 分钟前
准备考试:解决大学入学考试问题
数据结构·python·算法
.Vcoistnt1 小时前
Codeforces Round 994 (Div. 2)(A-D)
数据结构·c++·算法·贪心算法·动态规划
柒月的猫1 小时前
方格分割(蓝桥杯2017年试题D)
职场和发展·蓝桥杯
小猿_001 小时前
C语言实现顺序表详解
c语言·开发语言
ALISHENGYA1 小时前
全国青少年信息学奥林匹克竞赛(信奥赛)备考实战之分支结构(实战训练三)
数据结构·c++·算法·图论