PTA 乙級 1037. 在霍格沃茨找零錢(20)

1037. 在霍格沃茨找零錢(20)

時間限制
400 ms
內存限制
65536 kB
代碼長度限制
8000 B
判題程序
Standard
作者
CHEN, Yue

如果你是哈利·波特迷,你會知道魔法世界有它自己的貨幣系統 —— 就如海格告訴哈利的:“十七個銀西可(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


把錢換算爲最小單位,即Knut,參考:http://www.cnblogs.com/utank/p/4754157.html


#include <iostream>
#include <cstdio>
using namespace std;

const int MAXN = 3;
typedef struct node
{
	int g;//Galleon
	int s;//Sickle
	int k;//Knut

	bool operator <(const struct node &n)const
	{
		if (this->g != n.g)return this->g < n.g;
		else if (this->s != n.s)return this->s < n.s;
		else return this->k < n.k;
	}
}n;


int main() {
	
	n a,p,res;//a爲實付的錢,p爲應付的錢,res爲輸出的錢
	char c;//存儲.號
	cin >> p.g >> c >> p.s >> c >> p.k;
	cin>> a.g >> c  >> a.s >> c >> a.k;

	if (a < p)
	{
		printf("-");
		n temp = a;//交換a,p,使得a爲大的,p爲小的
		a = p;
		p = temp;
	}

	if (a.k < p.k)
	{
		a.k += 29;
		a.s--;
		res.k = a.k - p.k;
	}
	else res.k = a.k - p.k;

	if (a.s < p.s)
	{
		a.s += 17;
		a.g--;
		res.s = a.s - p.s;
	}
	else res.s = a.s - p.s;

	res.g = a.g - p.g;

	printf("%d.%d.%d\n",res.g,res.s,res.k);
	return 0;
}



發佈了111 篇原創文章 · 獲贊 44 · 訪問量 12萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章