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

输入格式:

输入在1行中分别给出P和A,格式为“Galleon.Sickle.Knut”,其间用1个空格分隔。这里Galleon是[0, 10^7]区间内的整数,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

solution1(有一个测试点木有过,获取数据忒笨了,烂的没心情改了

#include <stdio.h>
#include <string.h>
int input(char s1[], char s2[], int n1, int n2){
while(s2[n2] != '.' && n2 < strlen(s2)){
s1[n1++] = s2[n2++];
}
return n2;
}
int main(){
char p[30], a[30], flag = 1, t[30], gg[2][8], ss[2][3], kk[2][3];
int g[3], s[3], k[3], n[2] = {0};
scanf("%s %s", p, a);
if(strcmp(a, p) < 0){
flag = -1;
strcpy(t, a);
strcpy(a, p);
strcpy(p, t);
}
n[0] = input(gg[0], p, 0, 0);
n[1] = input(gg[1], a, 0, 0);
n[0] = input(ss[0], p, 0, ++n[0]);
n[1] = input(ss[1], a, 0, ++n[1]);
input(kk[0], p, 0, ++n[0]);
input(kk[1], a, 0, ++n[1]);
for(int i = 0; i < 2; i++){
sscanf(gg[i], "%d", &g[i]);
sscanf(ss[i], "%d", &s[i]);
sscanf(kk[i], "%d", &k[i]);
}
if(k[1] < k[0]){
s[1]--;
k[2] = k[1] - k[0] + 29;
}
else
k[2] = k[1] - k[0];
if(s[1] < s[0]){
g[1]--;
s[2] = s[1] - s[0] + 17;
}
else
s[2] = s[1] - s[0];
if(flag < 0)
printf("-");
g[2] = g[1] - g[0];
printf("%d.%d.%d", g[2], s[2], k[2]);
return 0;
}

solution2

#include <cstdio>
#include <algorithm>
using namespace std;
int main(){
int g[2], s[3], k[3];
scanf("%d.%d.%d %d.%d.%d", &g[0], &s[0], &k[0], &g[1], &s[1], &k[1]);
if(g[0] > g[1] || (g[0] == g[1] && s[0] > s[1]) || (g[0] == g[1] && s[0] == s[1] && k[0] > k[1])){
swap(g[0], g[1]);
swap(s[0], s[1]);
swap(k[0], k[1]);
printf("-");
}
if(k[1] < k[0]){
s[1]--;
k[2] = k[1] - k[0] + 29;
}
else
k[2] = k[1] - k[0];
if(s[1] < s[0]){
g[1]--;
s[2] = s[1] - s[0] + 17;
}
else
s[2] = s[1] - s[0];
printf("%d.%d.%d", g[1] - g[0], s[2], k[2]);
return 0;
}

solution3

#include <stdio.h>
#include <algorithm>
const int gallen = 17 * 29;
const int sickle = 29;
int main(){
int g[2], s[2], k[2], price[2];
scanf("%d.%d.%d %d.%d.%d", g, s, k, g + 1, s + 1, k + 1);
for(int i = 0; i < 2; i++)
price[i] = g[i] * gallen + s[i] * sickle + k[i];
price[1] -= price[0];
if(price[1] < 0){
price[1] *= -1;
printf("-");
}
printf("%d.%d.%d", price[1] / gallen, price[1] % gallen / sickle, price[1] % sickle);
return 0;
}

B1037 在霍格沃茨找零钱的更多相关文章

  1. 【算法笔记】B1037 在霍格沃茨找零钱

    1037 在霍格沃茨找零钱 (20 分) 如果你是哈利·波特迷,你会知道魔法世界有它自己的货币系统 —— 就如海格告诉哈利的:“十七个银西可(Sickle)兑一个加隆(Galleon),二十九个纳特( ...

  2. 【PAT】B1037 在霍格沃茨找零钱(20 分)

    #include<stdio.h> #include<string.h> #include<algorithm> using namespace std; int ...

  3. PAT-乙级-1037. 在霍格沃茨找零钱(20)

    1037. 在霍格沃茨找零钱(20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 如果你是哈利·波特迷,你会知 ...

  4. PAT 1037 在霍格沃茨找零钱(20)(代码+思路)

    1037 在霍格沃茨找零钱(20)(20 分) 如果你是哈利·波特迷,你会知道魔法世界有它自己的货币系统 -- 就如海格告诉哈利的:"十七个银西可(Sickle)兑一个加隆(Galleon) ...

  5. PAT 乙级 1037 在霍格沃茨找零钱(20)C++版

    1037. 在霍格沃茨找零钱(20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 如果你是哈利·波特迷,你会知 ...

  6. PAT——乙级1022:D进制的A+B &乙级1037:在霍格沃茨找零钱

    1022 D进制的A+B (20 point(s)) 输入两个非负 10 进制整数 A 和 B (≤2​30​​−1),输出 A+B 的 D (1<D≤10)进制数. 输入格式: 输入在一行中依 ...

  7. PAT (Basic Level) Practise (中文)-1037. 在霍格沃茨找零钱(20)

    PAT (Basic Level) Practise (中文)-1037. 在霍格沃茨找零钱(20) http://www.patest.cn/contests/pat-b-practise/1037 ...

  8. PAT(B) 1037 在霍格沃茨找零钱(Java)

    题目链接:1037 在霍格沃茨找零钱 (20 point(s)) 题目描述 如果你是哈利·波特迷,你会知道魔法世界有它自己的货币系统 -- 就如海格告诉哈利的:"十七个银西可(Sickle) ...

  9. P1037 在霍格沃茨找零钱

    转跳点:

  10. PAT 1037. 在霍格沃茨找零钱(20)

    如果你是哈利·波特迷,你会知道魔法世界有它自己的货币系统 -- 就如海格告诉哈利的:"十七个银西可(Sickle)兑一个加隆(Galleon),二十九个纳特(Knut)兑一个西可,很容易.& ...

随机推荐

  1. Azure Data Factory - [01] 触发器

    题记部分 一.概述   Azure Data Factory(后面简称ADF)的触发器是一种机制,用于在特定事件发生时自动执行数据管道.触发器可以基于事件间隔.数据变化或其他外部事件来启动数据管道的执 ...

  2. Kettle - 使用案例

    原文链接:https://blog.csdn.net/gdkyxy2013/article/details/117106691 案例一:把seaking的数据按id同步到seaking2,seakin ...

  3. 【BUUCTF】Easy MD5

    [BUUCTF]Easy MD5 (SQL注入.PHP代码审计) 题目来源 收录于:BUUCTF BJDCTF2020 题目描述 抓包得到提示 select * from 'admin' where ...

  4. 基于近红外与可见光双目摄像头的人脸识别与活体检测,文末附Demo

    基于近红外与可见光双目摄像头的活体人脸检测原理 人脸活体检测(Face Anti-Spoofing)是人脸识别系统中的重要一环,它负责验证捕捉到的人脸是否为真实活体,以抵御各种伪造攻击,如彩色纸张打印 ...

  5. Qt使用QAudioInput、QAudioOutput实现局域网的音频通话

    Qt使用QAudioInput.QAudioOutput实现局域网的音频通话 本文旨在介绍一下用Qt来实现局域网音频通话功能 文章目录 Qt使用QAudioInput.QAudioOutput实现局域 ...

  6. go切片排序

    前言 有时候我们需要根据切片中的某个字段进行切片排序,但sort包中只有默认基本类型 int . float64 和 string 的排序,所以我们可以手动实现sort包的 sort.Interfac ...

  7. 0003 Failed to build the application: build go_beego/src/hello: cannot load

    我使用beego框架快速建立了一个应用,可当我运行 bee run的时候,出现了如下错误 D:\go_beego\src\product>bee run ______ | ___ \ | |_/ ...

  8. laravel The Process class relies on proc_open, which is not available on your PHP installation.

    解决办法: 在php.ini中,找到disable_functions选项,看看后面是否有proc_open函数被禁用了,去掉proc_get_status,proc_open即可

  9. SpringBoot把本地的对象封装成为Nacos的配置对象

    你需要有个Nacos Nacos建立你的配置文件--建议yml文件 编写你的yml配置 platform: transaction: properties: notifyHost: "htt ...

  10. SpringBoot+Thymeleaf渲染下拉框异常解决

    常规方式 <select class="form-control" name="operationType" th:field="${itemT ...