ホグワーツ魔法魔術学校でのPTA A + B(20分)

無限の光を放つのは人間の心であり、無限の闇を生み出すのも人間の心であり、光と闇が絡み合って戦うこの世界は、懐かしくて無力な世界です。

ハリーポッターのファンなら、魔法の世界に独自の通貨システムがあることを知っているでしょう。ハグリッドがハリーに説明したように、「17の銀の鎌をガレオンに、29のナッツを鎌に、それは十分簡単です。 」あなたの仕事は、A及びBは、標準的な形で示されているA + Bを計算するプログラムを書くことであること  Galleon.Sickle.Knut (Galleon [0,10 7]内の整数である、  Sickle の整数であり、[0、17)、そして  Knut あります[0、29)の整数。

入力仕様:

各入力ファイルには、1つのスペースで区切られた、標準形式のAおよびBの行を占める1つのテストケースが含まれています。

出力仕様:

テストケースごとに、AとBの合計を入力と同じ形式で1行に出力する必要があります。

入力例:

3.2.1 10.16.27

出力例:

14.1.28
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <string>
#include <cstring>
#include <cstdlib>
#include <cmath>
#include <stack>
#include <queue>
#include <set>
#include <map>
#include <vector>
#include <ctime>
#include <cctype>
#include <bitset>
#include <utility>
#include <sstream>
#include <complex>
#include <iomanip>
#include<climits>//INT_MAX
#define PP pair<ll,int>
#define inf 0x3f3f3f3f
#define llinf 0x3f3f3f3f3f3f3f3fll
#define dinf 1000000000000.0
#define PI 3.1415926
typedef long long ll;
using namespace std;
int const mod=1e9+7;
const int maxn=3e5+10;
ll S1[3],S2[3],fg[3],C[3]={10000000,17,29};
int main()
{
    scanf("%lld.%lld.%lld %lld.%lld.%lld", &S1[0], &S1[1], &S1[2], &S2[0], &S2[1], &S2[2]);
    for (ll i=2; i>=0; i--)
    {
        S1[i]+=S2[i]+fg[i];
        if (S1[i]>=C[i]&&i!=0)
        {
            fg[i-1]=S1[i]/C[i];
            S1[i]%=C[i];
        }
    }
    printf("%lld.%lld.%lld", S1[0], S1[1], S1[2]);
    return 0;
}
 

おすすめ

転載: blog.csdn.net/weixin_44170305/article/details/108380039