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
#include <iostream>
#include <math.h>
using namespace std;
int main(){
	int a,b,c,d,e,f,sum1,sum2,x1,x2,x3;
	scanf("%d.%d.%d",&a,&b,&c);
	scanf("%d.%d.%d",&d,&e,&f);
	sum1=a*17*29+b*29+c;
	sum2=d*17*29+e*29+f;
	int x=sum2-sum1;
	x1=x/(17*29);
	x2=x%(17*29)/29;
	x3=x%(17*29)%29;
	if(x<0){
		printf("-");
	}
	printf("%d.%d.%d",abs(x1),abs(x2),abs(x3));
	return 0;
}








發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章