题目链接:点击打开链接
If you are a fan of Harry Potter, you would know the world of magic has its own currency system -- as Hagrid explained it to Harry, "Seventeen silver Sickles to a Galleon and twenty-nine Knuts to a Sickle, it's easy enough." Your job is to write a program to compute A+B where A and B are given in the standard form of "Galleon.Sickle.Knut" (Galleon is an integer in [0, 107], Sickle is an integer in [0, 17), and Knut is an integer in [0, 29)).
Input Specification:
Each input file contains one test case which occupies a line with A and B in the standard form, separated by one space.
Output Specification:
For each test case you should output the sum of A and B in one line, with the same format as the input.
Sample Input:3.2.1 10.16.27Sample Output:
14.1.28python2程序:
inputs=[i for i in raw_input().split()]
p=[int(i) for i in inputs[0].split('.')]
a=[int(i) for i in inputs[1].split('.')]
p_sum = p[0]*493+ p[1]*29 + p[2]
a_sum = a[0]*493+ a[1]*29+ a[2]
sum = a_sum+p_sum
print"%d.%d.%d"%(sum/493,sum/29%17,sum%29)
========
上面的解法用c语言写竟然错了一个测试点,换种解法用C++写。
#include<iostream>
using namespace std;
int main()
{
int i = 0, p[3], a[3]; //p[0]应该付的加隆,p[1]应该付的西可,p[2]应付的纳特
int p_sum, a_sum; //p_sum兑换成基本单位后的应付总价钱
int sum[3] = {0,0,0}; //sum总额
char c;
cin >> p[0] >> c >> p[1] >> c >> p[2];
cin>>a[0] >> c >> a[1] >> c >> a[2];
sum[2] = p[2] + a[2];
if (sum[2] >= 29)//纳特之和大于等于29,西可加一位
{
sum[1]=1;
sum[2] = sum[2] - 29;
}
sum[1] =sum[1]+p[1] + a[1];
if (sum[1] >= 17)
{
sum[0]=1;
sum[1] = sum[1] - 17;
}
sum[0] = sum[0] + p[0] + a[0];
printf("%d.%d.%d",sum[0],sum[1],sum[2]);
//system("pause");
return 0;
}