75962024-01-10 00:33:35rennAutókódoláscpp14Részben helyes 47/503ms3984 KiB
#include <bits/stdc++.h>
using namespace std;

int main() {

    long long nagy, kicsi, j = -1, h = 0;
    cin >> nagy;

    //bitset<40> a(nagy);
    kicsi = nagy;

    bool prev = true, most = true;
    for(long long i = 0, k; i < 41; i++) {
        prev = most;
        most = (kicsi & (1LL << i));

        h += most;
        kicsi ^= ((long long)most << i);
        if(most && !prev) {
            //kicsi ^= (0LL << (i));

            for(k = 0; k < h; k++) {
                kicsi ^= (1LL << (i-k-1));
            }
            break;
        }
    }

    prev = most = false;
    for(long long i = 0, k; i < 41; i++) {
        prev = most;
        most = (nagy & (1LL << i));

        j += most;

        nagy ^= ((long long)most << i);
        if(!most && prev) {
            nagy ^= (1LL << i);

            for(k = 0; k < j; k++) {
                nagy ^= (1LL << k);
            }
            break;
        }
    }
    //bitset<40> b(kicsi);
    //bitset<40> c(nagy);
    //cout << a << "\n";
    cout << (h < 1 ? h : kicsi) << "\n";
    //out << b << "\n";
    cout << nagy << "\n";
    //cout << c << "\n";

    return 0;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base47/50
1Elfogadva0/03ms1872 KiB
2Elfogadva0/03ms2068 KiB
3Részben helyes1/23ms2436 KiB
4Elfogadva2/23ms2436 KiB
5Elfogadva2/22ms2508 KiB
6Elfogadva2/23ms2512 KiB
7Elfogadva2/23ms2796 KiB
8Elfogadva4/43ms2860 KiB
9Elfogadva4/43ms2872 KiB
10Elfogadva4/43ms3064 KiB
11Elfogadva4/42ms3152 KiB
12Elfogadva4/43ms3276 KiB
13Részben helyes2/43ms3388 KiB
14Elfogadva4/43ms3480 KiB
15Elfogadva4/42ms3472 KiB
16Elfogadva4/43ms3724 KiB
17Elfogadva4/43ms3984 KiB