leetcode6055.转化时间需要的最少操作数(周赛,简单)

在这里插入图片描述
在这里插入图片描述
自已一开始的思路,模拟。代码如下:
出现的错误
1:小时模拟代码比较复杂。
2:数字->字符:+‘0’
3:字符转数字:-‘0’

思路二:都分别直接转化为距离00:00过了多少分钟,也就是转化成60进制

class Solution {
public:
    int convertTime(string cu, string co) { 
        int a = stoi(cu.substr(0, 2)) * 60 + stoi(cu.substr(3, 2));
        int b = stoi(co.substr(0, 2)) * 60 + stoi(co.substr(3, 2));
        int c = (b - a + 1440) % 1440; //
        int ans = c / 60;
        c = c % 60;
        ans += c / 15;
        c = c % 15;
        ans += c / 5;
        c = c % 5;
        ans += c;
        return ans;
    }
};

注意: 如果题目没有cu <= co的话这一步要加:c = (b - a + 1440) % 1440;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值