求助帖(脑壳都秃了)

警察在侦破一个案件时,得到了线人给出的可能犯罪时间,形如 “HH:MM” 表示的时刻。
根据警察和线人的约定,为了隐蔽,该时间是修改过的,解密规则为:利用当前出现过的数字,构造下一个距离当前时间最近的时刻,则该时间为可能的犯罪时间。每个出现数字都可以被无限次使用。"
"输入描述:
形如HH:SS的字符串,表示原始输入
输出描述:
形如HH:SS的字符串,表示推理出来的犯罪时间
示例1
输入              输出
18:52            18:55
说明
利用数字1, 8, 5, 2构造出来的最近时刻是18:55,是3分钟之后。结果不是18:51因为这个时刻是23小时59分钟之后。
示例2
输入            输出
23:59          22:22
说明
利用数字2, 3, 5, 9构造出来的最近时刻是22:22。 答案一定是第二天的某一时刻,所以选择可构造的最小时刻为犯罪时间。
备注:
1,可以保证线人给定的字符串一定是合法的。例如,“01:35” 和 “11:08” 是合法的,“1:35” 和 “11:8” 是不合法的。

2,最近的时刻有可能在第二天

萌新一个,真想不到什么好的解决办法(——v——)
#华为机试##笔试题目#
全部评论
咋感觉有点像牛客的题
1 回复 分享
发布于 2022-02-24 23:35
穷举思路,抛砖引玉。 输入其实给了两重信息:一是锚时间(构造的时间默认是比锚时间晚的,且要离锚时间越近越好)二是可用数字(构造时间的数字只能使用这四个,每个数字可以重复使用)。 那么可以先构建一个函数,输入两个时间,返回时间差(默认第二个时间晚于第一个时间,所以差为负的加一天)。 然后遍历输入内容里四个数字的各种可能的时间组合(注意小时在0-23之间,分钟在00-59之间)找出能够得到最小时间差的组合即可。
1 回复 分享
发布于 2022-03-02 22:04
枚举时间,判断是否合法就可以了
点赞 回复 分享
发布于 2022-04-23 21:57
这题与“从已知的数字,组合出一个比原来稍大的数字”很像,差别是时间格式的“时、分”大小有限制。 比如 1829 稍大的数是 1889,但1889却不是合法的时分。 思路: 1 按照组合出稍大数字的思路,加上时分格式合法判断来处理。 2 从最低权重位(个位数)数开始遍历,用稍大的数替换当前数,再判断合法性。 a) 如果在某个权重位替换成功。再把该位置后续的数替换成最小的数。 b) 如果到了千位数,也没找到合法的替换,那意味着应用用第二天最小时间了。以1829来说,取出最小数字“1”,那就是11:11。
点赞 回复 分享
发布于 2023-04-21 22:13 广东

相关推荐

微风不断:兄弟,你把四旋翼都做出来了那个挺难的吧
点赞 评论 收藏
分享
1 5 评论
分享
牛客网
牛客企业服务