美文网首页
2019-08-21 B1037 在霍格沃茨找零钱

2019-08-21 B1037 在霍格沃茨找零钱

作者: JO炮 | 来源:发表于2019-08-21 11:12 被阅读0次

这道题不难但是我写的代码十分啰嗦,参考了柳神的代码简化后如下:

#include <iostream>
using namespace std;

int main() {
    int a, b, c, l, m, n, x, y, z;
    scanf("%d.%d.%d %d.%d.%d", &a, &b, &c, &l, &m, &n);
    if( l < a || (l == a && m < b) || (l == a && m == b && n < c)){
        swap(a,l); swap(b, m); swap(c, n);
        printf("-");
    }
    z = n < c ? n -c + 29 : n - c;
    m = n < c ? m - 1 : m;
    y = m < b ? m - b + 17 : m - b;
    x = m < b ? l - a -1 : l - a;
    printf("%d.%d.%d", x, y, z);
    
    return 0;
}

主要是对最后判断各位上的数够不够减需不需要借位的那几句做了优化,以后在刷题的时候也要灵活运用这个三目运算符,不要只想着用ifelse语句来写。

相关文章

网友评论

      本文标题:2019-08-21 B1037 在霍格沃茨找零钱

      本文链接:https://www.haomeiwen.com/subject/ohqzdctx.html