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

本文介绍了一个算法,用于计算在给定时间内,电子钟显示的等差数列时刻(好时刻)的数量。通过输入总观测时间,算法能够计算并输出好时刻出现的次数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述

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

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

输入格式

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

输出格式

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

输入输出样例

输入 #1复制

120

输出 #1复制

10

输入 #2复制

2880

输出 #2复制

79

输入 #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 个。


import java.util.Scanner;

public class Main {
	
	public static void main(String[] args) {
		
		Scanner inp = new Scanner(System.in);
		
		Integer mm = inp.nextInt();
		int num = 0;
		while(mm>1440) {
			num = num+39*(mm/1440);
			mm = mm%1440;
		}
		for(Integer i = 0;i<=mm;i++) {
			int h = i/60;
			num = num+dfs(i,h);
		}
		System.out.print(num);
	}
	
	public static int dfs(Integer mm,int h) {

		int m = mm%60;
		int m1 = m/10;
		int m2 = m%10;
		if(h<10) {
			if((m2-m1)==(m1-h)) {
				return 1;
			}
		}else {
			if(h==24) {
				return 1;
			}
			int h1 = h/10;
			int h2 = h%10;
			if((m2-m1)==(m1-h2)&&(m1-h2)==(h2-h1)) {
				return 1;
			}
		}
		return 0;
	}
	
}

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

萤火的微亮

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值