• pat 1037


    如果你是哈利·波特迷,你会知道魔法世界有它自己的货币系统 —— 就如海格告诉哈利的:“十七个银西可(Sickle)兑一个加隆(Galleon),二十九个纳特(Knut)兑一个西可,很容易。”现在,给定哈利应付的价钱P和他实付的钱A,你的任务是写一个程序来计算他应该被找的零钱。

    输入格式:

    输入在1行中分别给出P和A,格式为“Galleon.Sickle.Knut”,其间用1个空格分隔。这里Galleon是[0, 107]区间内的整数,Sickle是[0, 17)区间内的整数,Knut是[0, 29)区间内的整数。

    输出格式:

    在一行中用与输入同样的格式输出哈利应该被找的零钱。如果他没带够钱,那么输出的应该是负数。

    输入样例1:

    10.16.27 14.1.28
    

    输出样例1:

    3.2.1
    

    输入样例2:

    14.1.28 10.16.27
    

    输出样例2:

    -3.2.1




    # include<iostream>
    # include<stdio.h>
    using namespace std;
    int main()
    {
    int g,s,k,g1,s1,k1,g2,s2,k2,sum1,sum2,cha;
    scanf("%d.%d.%d",&g1,&s1,&k1);
    scanf("%d.%d.%d",&g2,&s2,&k2);
    sum1 = 17*29*g1 + 29*s1 +k1;                                 /////有三个单位   统一化为最小的单位进行运算
    sum2 = 17*29*g2 + 29*s2 +k2;
    if(sum2 - sum1 >= 0)
    {
    cha = sum2 - sum1;
    g = cha / (17 * 29);
    s = (cha - 17*29*g) / 29;
    k = cha - 17*29*g - 29*s;
    cout<<g<<"."<<s<<"."<<k;
    }
    else                                                  ////思考没带够钱的情况----将负数转化为正数来做
    {
    cha = sum1 - sum2;
    g = cha / (17 * 29);
    s = (cha - 17*29*g) / 29;
    k = cha - 17*29*g - 29*s;
    cout<<"-"<<g<<"."<<s<<"."<<k;
    }

    return 0;
    }

  • 相关阅读:
    帧同步资料收集
    随机数种子问题
    【转】 DOTA2中的伪随机及其lua实现
    C++ 异常机制分析
    细说new与malloc的10点区别
    static关键字总结
    C++11 并发编程基础(一):并发、并行与C++多线程
    论一个程序员的自我修养
    gSoap的多线程程序
    面试常见问题:
  • 原文地址:https://www.cnblogs.com/wshyj/p/6279992.html
Copyright © 2020-2023  润新知