【算法】传智杯练习赛:时钟

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

题目描述

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

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

输入格式

一个不超过 1 0 9 10^9 109 的非负整数。

输出格式

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

样例 #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 个。

AC代码

#include<iostream>

using namespace std;

int main(){
	int n,days,ans=0;
	cin>>n;
	days=n/1440,n%=1440;
	ans=days*39;
	for(int i=0;i<24;i++)
		for(int j=0;j<60;j++){
			int a=i/10,b=i%10,c=j/10,d=j%10;
			if(i<=9){
				if((b-c)==(c-d)){
					ans++;
				}
			}else if(i>=10){
				if((a-b)==(b-c)&&(b-c)==(c-d)){
					ans++;
				}
			}
			n--;
			if(n<0)break;
		}
	cout<<ans;
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值