从零开始刷题1

又一道简单等级的题,小白打小怪~

​​​​​​​

最大时间:
给定一个由 4 位数字组成的数组,返回可以设置的符合 24 小时制的最大时间。最小的 24 小时制时间是 00:00,而最大的是 23:59。从 00:00 (午夜)开始算起,过得越久,时间越大。以长度为 5 的字符串返回答案。如果不能确定有效时间,则返回空字符串。
来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/largest-time-for-given-digits侵删

 

思路一:

可能很多同学拿到题的第一时间是想直接判断最小值应该小于3,次小值应该小于6等,按照条件去筛选,这样就会分很多if else,一定程度上增加了做题的时间

 

思路二:

对于本题,由于只有四位,可以直接遍历所有排列,也不会有太多排列,此时暴力反而会节省思考的时间

​​​​​​​

class Solution(object):    def largestTimeFromDigits(self, A):        """        :type A: List[int]        :rtype: str        """        max_time=-1        for h1,h2,m1,m2 in itertools.permutations(A):            hour=h1*10+h2            mins=m1*10+m2            time=hour*60+mins            if  hour>23 or mins>59:                continue            elif max_time<time:                max_time=time        return "{:02d}:{:02d}".format(*divmod(max_time, 60)) if max_time>-1 else ""              

知识点:

  1. itertools.permutations

  2. "{:02d}:{:02d}".format format的用法非常多可以直接转换进制等,有兴趣的同学可以查查,比如网上查以下几个小?

     

tplt = "{0:^10}\t{1:{3}^10}\t{2:^10}"   # {1:{3}^10} 1表示位置,{3}表示用第3个参数来填充,^表示居中,10表示占10个位置'{:,}'.format(1234567890)=》 '1,234,567,890'^、<、>分别是居中、左对齐、右对齐,后面带宽度:号后面带填充的字符,只能是一个字符,不指定的话默认是用空格填充
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值