[传智杯 #5 练习赛] 时钟

简介: [传智杯 #5 练习赛] 时钟

[传智杯 #5 练习赛] 时钟

题目描述

你有一个电子钟,可以显示 0:0023:59 之间的所有时间,以数字的形式显示。其中小时是 023(0 时会显示一个 0,而 1 到 9 时不会显示前导 0),分钟是 0059(0 到 9 分都会显示前导 0)。任何时刻,电子钟都会显示三个或者四个 $0$ 到 $9$ 的数字。如果在某时刻,这些数字依次组成了一个等差数列,则这个时刻被称为“好时刻”。

你感觉很无聊,从 0:00 时刻开始盯着这个电子钟。一共盯了 $x$ 分钟。请问整个过程中,"好时刻"来临了多少次(算上开头和结尾)?

输入格式

一个不超过 $10^9$ 的非负整数。

输出格式

请输出"好时刻"来临了多少次?

样例 #1

样例输入 #1

120

样例输出 #1

10

样例 #2

样例输入 #2

2880

样例输出 #2

79

样例 #3

样例输入 #3

987654321

样例输出 #3

26748975

提示

【样例解释】

你观察了 2 个小时,其中这些“好时刻”来临了:

0:00
0:12
0:24
0:36
0:48
1:11
1:23
1:35
1:47
1:59

一共是 10 个。

题解

#include<stdio.h>

int main(){
    int hour,minute,one,two,three,four,time,cir,mod,num = 0;
    scanf("%d",&time);
    cir = time/1440;
    mod = time%1440;
    num += cir*39;
    hour = mod/60;
    minute = mod%60;
    if(hour<10){
        one = hour;
        two = minute/10;
        three = minute%10;
        for(int i=0;i<one;i++){
            for(int j=0;j<=5;j++){
                for(int k=0;k<=9;k++){
                    if(k-j==j-i){
                        num++;
                    }
                }
            }
        }
        for(int j=0;j<two;j++){
            for(int k=0;k<=9;k++){
                if(k-j==j-one){
                    num++;
                }
            }
        }
        for(int k=0;k<=three;k++){
            if(k-two==two-one){
                num++;
            }
        }
    }else{
        num += 34;
        one = hour/10;
        two = hour%10;
        three = minute/10;
        four = minute%10;
        for(int i=1;i<one;i++){
            for(int j=0;j<=3;j++){
                for(int k=0;k<=5;k++){
                    for(int l=0;l<=9;l++){
                        if(l-k==k-j && k-j == j-i){
                            num++;
                        }
                    }
                }
            }
        }
        for(int j=0;j<two;j++){
            for(int k=0;k<=5;k++){
                for(int l=0;l<=9;l++){
                    if(l-k==k-j && k-j == j-one){
                        num++;
                    }
                }
            }
        }
        for(int k=0;k<three;k++){
            for(int l=0;l<=9;l++){
                if(l-k==k-two && k-two == two-one){
                    num++;
                }
            }
        }
        for(int l=0;l<=four;l++){
            if(l-three==three-two && three-two == two-one){
                num++;
            }
        }
    }
    printf("%d",num);
    return 0;
}
相关文章
|
存储 自然语言处理 数据可视化
【软件设计师备考 专题 】设计数据模型:ER模型和数据模型
【软件设计师备考 专题 】设计数据模型:ER模型和数据模型
547 0
|
机器学习/深度学习 人工智能 监控
【AI 现况分析】AI大模型在财务规划和建议中的应用
【1月更文挑战第27天】【AI 现况分析】AI大模型在财务规划和建议中的应用
|
11月前
|
网络协议 网络架构
HCIP-datacom 真题 (2024年下半年最新题库)
HCIP-datacom 真题 (2024年下半年最新题库)
711 0
|
10月前
|
监控 安全
网络传输介质
本文介绍了有线传输介质和无线传输介质。有线传输介质包括双绞线、同轴电缆和光纤,其中双绞线因其成本低、安装便捷而广泛应用;同轴电缆适合长距离传输视频信号;光纤则具有高速、抗干扰等优势。无线传输介质涵盖无线电波、微波、红外线和蓝牙,适用于不同场景下的无线通信需求。
367 1
网络传输介质
|
存储 Kubernetes Docker
Kubernetes(K8S)集群管理Docker容器(概念篇)
Kubernetes(K8S)集群管理Docker容器(概念篇)
|
10月前
|
安全 搜索推荐 Android开发
揭秘iOS与安卓系统的差异:一场技术与哲学的较量
在智能手机的世界里,iOS和Android无疑是两大巨头,它们不仅定义了操作系统的标准,也深刻影响了全球数亿用户的日常生活。本文旨在探讨这两个平台在设计理念、用户体验、生态系统及安全性等方面的本质区别,揭示它们背后的技术哲学和市场策略。通过对比分析,我们将发现,选择iOS或Android,不仅仅是选择一个操作系统,更是选择了一种生活方式和技术信仰。
|
10月前
|
Java 测试技术 API
Java零基础-接口详解
【10月更文挑战第19天】Java零基础教学篇,手把手实践教学!
267 1
|
UED 开发者 Windows
操作系统的演变:从命令行到图形用户界面
【8月更文挑战第8天】 在这篇文章中,我们将探索操作系统的发展历程,从最初的命令行界面到现代的图形用户界面。我们将深入了解这些变化如何影响了计算机的使用和普及,以及它们对软件开发和用户体验的影响。
257 2
|
Java 数据库连接 mybatis
在Spring Boot应用中集成MyBatis与MyBatis-Plus
在Spring Boot应用中集成MyBatis与MyBatis-Plus
341 5
|
机器学习/深度学习 Python
sigmoid函数
本文探讨了高等数学中的sigmoid函数,它在神经网络中的应用,特别是在二分类问题的输出层。sigmoid函数公式为 $\frac{1}{1 + e^{-x}}$,其导数为 $sigmoid(x)\cdot(1-sigmoid(x))$。文章还展示了sigmoid函数的图像,并提供了一个使用Python绘制函数及其导数的代码示例。
757 2