【PAT B-1037】在霍格沃茨找零钱

【PAT B-1037】在霍格沃茨找零钱

C++代码

方法一:

// 将输入数据统一转换到最小单位,进行指定运算后,再将得到的结果转换到所要输出的格式
#include <bits/stdc++.h>
using namespace std;
using gg = long long;
int main() {
    ios::sync_with_stdio(false);
    cin.tie(0);
    gg g1, s1, k1, g2, s2, k2;
    char c;  //读取小数点
    cin >> g1 >> c >> s1 >> c >> k1 >> g2 >> c >> s2 >> c >> k2;
    //将输入数据统一转换到最小单位
    gg t1 = (g1 * 17 + s1) * 29 + k1, t2 = (g2 * 17 + s2) * 29 + k2;
    t2 -= t1;
    cout << t2 / 29 / 17 << '.' << abs(t2) / 29 % 17 << '.' << abs(t2) % 29;
    return 0;
}

方法二:

// 从最小单位开始进行指定运算,向上级单位产生进位或借位,得出最终结果。
#include <bits/stdc++.h>
using namespace std;
using gg = long long;
struct T {
    gg g, s, k;
    bool operator<(const T& t) const {
        return tie(g, s, k) < tie(t.g, t.s, t.k);
    }
};
int main() {
    ios::sync_with_stdio(false);
    cin.tie(0);
    T t1, t2;
    char c;  //读取小数点
    cin >> t1.g >> c >> t1.s >> c >> t1.k >> t2.g >> c >> t2.s >> c >> t2.k;
    if (t2 < t1) {
        cout << '-';
        swap(t1, t2);
    }
    if (t2.k < t1.k) {  //向高位借位
        t2.k = t2.k + 29;
        --t2.s;
    }
    if (t2.s < t1.s) {  //向高位借位
        t2.s = t2.s + 17;
        --t2.g;
    }
    cout << t2.g - t1.g << '.' << t2.s - t1.s << '.' << t2.k - t1.k;
    return 0;
}
  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

我真的不是cjc

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

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

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

打赏作者

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

抵扣说明:

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

余额充值