如果你是哈利·波特迷,你会知道魔法世界有它自己的货币系统 —— 就如海格告诉哈利的:“十七个银西可(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. Scala样例类及底层实现伴生对象

    package com.wyh.day01 /** * 样例类的使用 * 1.使用case修饰类 * 2.不需要写构造方法,getter,setter方法,toString方法 * 3.直接通过对象名 ...

  2. 解决win11输入法自定义短语有多个当前日期只有最后一个生效

    由于win11自定义短语保存机制问题导致只有最后一个当前日期短语生效** 1.首先找到自定义短语存储文件的具体路径:%AppData%\Microsoft\InputMethod\Chs\ 拼音输入法 ...

  3. win7系统安装mysql新建数据库/数据表及故障处理,安装mysql后net start mysql服务无法启动

    问题描述:win7系统安装mysql,安装mysql后net start mysql服务无法启动 1.下载mysql: 官网地址:https://dev.mysql.com/downloads/mys ...

  4. Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库

    #div_digg { float: right; font-size: 12px; margin: 10px; text-align: center; width: 120px; position: ...

  5. Swagger OpenAPI Schema 为空时 Example Value 显示 "string" 的原因及解决方案

    解决Swagger UI示例值显示"string"的问题 最近在使用ObjectScript生成JSON接口文档时,遇到了一个奇怪的问题: 生成的JSON数据是正常的. 但Swag ...

  6. 第十八届全国大学生信息安全竞赛暨第二届“长城杯”铁人三项赛web方向部分wp

    第十八届全国大学生信息安全竞赛暨第二届"长城杯"铁人三项赛web方向部分wp hello_web 查看源代码发现有两个文件,访问一下 Tips是phpinfo 里面可以看到disa ...

  7. mysql frm、MYD、MYI数据文件恢复,导入MySQL中

    前言 .frm..MYI..MYD 文件分别是 MySQL 的 MyISAM存储引擎存储的表结构.索引.数据文件. 简单方法恢复数据 .frm..MYI..MYD文件如果直接以文本打开,全部会以二进制 ...

  8. go 判断数组下标是否存在

    举例 现在需要判断命令行是否传了参数,即 os.Args[1] 是否存在 如果使用下述的判断: func main() { fmt.Println(os.Args[1]) } 会报错:index ou ...

  9. php7有哪些新特性

    目录 太空船操作符 标量类型声明和返回值的类型说明 null 合并操作符 常量数组 namespace 批量导入 非混合模式的 use 声明 混合模式的 use 声明 复合模式的 use 声明 thr ...

  10. 基于DotNetty实现自动发布 - 背景篇

    故事背景 小公司,单体项目,接口和页面都在一起,生产和测试环境都是 Windows 服务器和 IIS, 本地编译完成,把相关的页面和程序集拷贝到服务器上,尤其是涉及到多个页面,一个个页面找到对应的位置 ...