結果

問題 No.381 名声値を稼ごう Extra
ユーザー h_nosonh_noson
提出日時 2016-06-18 01:23:39
言語 C++11
(gcc 11.4.0)
結果
WA  
実行時間 -
コード長 1,291 bytes
コンパイル時間 542 ms
コンパイル使用メモリ 66,544 KB
実行使用メモリ 6,820 KB
最終ジャッジ日時 2024-10-09 20:13:56
合計ジャッジ時間 1,683 ms
ジャッジサーバーID
(参考情報)
judge1 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 WA -
testcase_01 OLE -
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <iostream>
#include <vector>
#include <map>
#include <algorithm>
using namespace std;

#define REP(i,s,e) for (i = s; i <= e; i++)
#define rep(i,n) REP (i,0,(int)(n)-1)
#define RREP(i,s,e) for (i = s; i >= e; i--)
#define rrep(i,n) RREP (i,(int)(n)-1,0)
#define INF (int)1e8
#define MOD 1004535809

typedef long long ll;

ll num[100000];

ll power(ll x, int n) {
    ll ret = 1;
    while (n) {
        if (n % 2)
            ret *= x;
        x *= x;
        n /= 2;
    }
    return ret;
}

int main(void) {
    int i, n;
    string s;
    cin >> s;
    n = s.size();
    int digit = 0;
    int j = 0;
    rrep (i,n) {
        if (j == 18) {
            j = 0;
            digit++;
        }
        num[digit] += (s[i] - '0') * power(10,j);
        j++;
    }
    digit++;
    int ans = 0;
    while (true) {
        ans += num[0] % 2;
        ll carry = 0;
        bool end = true;
        rrep (i,digit)
            cout << num[i] << " ";
        cout << endl;
        rrep (i,digit) {
            num[i] += carry;
            if (num[i] % 2)
                carry = 1e18;
            else
                carry = 0;
            num[i] /= 2;
            if (num[i] != 0) end = false;
        }
        if (end)
            break;
    }
    cout << ans << endl;
    return 0;
}
0