B1037 在霍格沃茨找零钱

126 篇文章 0 订阅

如果你是哈利·波特迷,你会知道魔法世界有它自己的货币系统 —— 就如海格告诉哈利的:“十七个银西可(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;
}

solution3.1

#include <cstdio>
#include <algorithm>
using namespace std;
int main(){
	int n[2], g[2], s[2], k[2], flag = 1;
	for(int i = 0; i < 2; i++){
		scanf("%d.%d.%d", g + i, s + i, k + i);
		n[i] = g[i] * 17 * 29 + s[i] * 29 + k[i];
	}
	if(n[0] > n[1])	{
		flag = -1;
		swap(n[0], n[1]);	
	}
	n[1] -= n[0];
	printf("%d.%d.%d", flag*(n[1] / 493), n[1] % 493 / 29, n[1] % 29);
	return 0;
}

在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值