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

cpp 复制代码
/*
本题主要是不同进制之间的减法;可以考虑将数据化成最小的权
的形式,就是将加隆银西全部转换为纳特,再进行加减;然后再
转化成加隆.银西.纳特的形式;注意每位空着的要用0补齐;
就是0也应该以0.0.0的格式输出;
*/
#include<iostream>
#include<string>
using namespace std;
struct Money{
    int Galleon;
    int Sickle;
    int Knut;
    int total;
};
typedef struct Money money;
typedef struct Money price;
//钱币输入函数;
struct Money input(){
    struct Money ret;
    int G;    //Galleon;
    int S;    //Sickle;
    int K;    //Knut;
    cin>>G;
    getchar();
    cin>>S;
    getchar();
    cin>>K;
    ret.Galleon=G;
    ret.Sickle=S;
    ret.Knut=K;
    ret.total=G*17*29+S*29+K;    //换算成纳特;
    return ret;
}
//将纳特换算成 加隆.银西.纳特 格式的函数;
struct Money IntToMoney(int sub){
    struct Money ret;
    if(sub<0){
        sub=-sub;
    }
    ret.total=sub;
    ret.Galleon=sub/(17*29);    //这里有可能是0;
    sub=sub-(17*29)*ret.Galleon;
    ret.Sickle=sub/29;
    sub=sub-29*ret.Sickle;
    ret.Knut=sub;
    return ret;
}
//输出钱币的函数;
void output(struct Money out){
    cout<<out.Galleon<<'.'<<out.Sickle<<'.'<<out.Knut<<endl;
}
int main(){
    //输入;
    price P;
    P=input();    //输入价格;
    money A;
    A=input();    //输入钱;
    //计算差价;
    int sub=A.total-P.total;    //纳特格式下的差价;
    //输出;
    if(sub<0){    //若为负数则输出负号;
        cout<<'-';
    }
    money out=IntToMoney(sub);
    output(out);
    return 0;
}
相关推荐
楼田莉子2 小时前
C++学习:C++11介绍及其新特性学习
开发语言·c++·学习·stl·visual studio
不枯石2 小时前
Matlab通过GUI实现点云的随机一致性(RANSAC)配准
开发语言·图像处理·算法·计算机视觉·matlab
WWZZ20253 小时前
ORB_SLAM2原理及代码解析:Tracking::CreateInitialMapMonocular() 函数
人工智能·opencv·算法·计算机视觉·机器人·slam·感知
WWZZ20253 小时前
ORB_SLAM2原理及代码解析:Tracking::MonocularInitialization() 函数
人工智能·opencv·算法·计算机视觉·机器人·感知·单目相机
光电笑映4 小时前
C++list全解析
c语言·开发语言·数据结构·c++·list
L_09075 小时前
【Algorithm】双指针算法与滑动窗口算法
c++·算法
小龙报5 小时前
《构建模块化思维---函数(下)》
c语言·开发语言·c++·算法·visualstudio·学习方法
奔跑吧邓邓子5 小时前
【C++实战(63)】C++ 网络编程实战:UDP客户端与服务端的奥秘之旅
网络·c++·udp·实战·客户端·服务端
952366 小时前
数据结构—双链表
c语言·开发语言·数据结构·学习
祁同伟.6 小时前
【C++】继承
开发语言·c++