5502021-11-03 20:17:22SzankaBenedekToronyépítés (1,1,3,3)cpp11Hibás válasz 0/502ms1972 KiB
#include <iostream>
#include <vector>

using namespace std;

int main()
{
    cin.sync_with_stdio(false);
    cin.tie(nullptr);

    unsigned int N;
    cin >> N;

    unsigned long long int a = 2;
    unsigned long long int b = 4;
    unsigned long long int c = 10;

    unsigned int NN;
    for (int n = 3; n < N; n += 3)
    {
        a = 2 * (c + a);
        b = 2 * (a + b);
        c = 2 * (b + c);
        if (c >= 2021010800000)
        {
            c %= 20210108;
            a %= 20210108;
            b %= 20210108;
        }
        // a = a >= 20210108 ? a % 20210108 : a;
        // b = b >= 20210108 ? b % 20210108 : b;
        // c = c >= 20210108 ? c % 20210108 : c;
        NN -= 3;
    }

    switch (NN)
    {
    case 3:
        cout << c % 20210108;
        break;
    case 1:
        cout << a % 20210108;
        break;
    case 2:
        cout << b % 20210108;
        break;
    }
}

// int t[3];
// a = 2;
// b = 4;
// c = 10;
// for (; i > 3; i -= 3)
// {
//     a = (2 * c + 2 * a) % 20210108;
//     b = (2 * a + 2 * b) % 20210108;
//     c = (2 * b + 2 * c) % 20210108;
// }
// cout << t[i - 1] << "\n";
//=================================//
// int v[input];
// v[0] = 2;
// v[1] = 4;
// v[2] = 10; //8+2
// for (int n = 3; n < input; n++)
// {
//     v[n] = (2 * v[n - 1] + 2 * v[n - 3]) % 20210108;
// }
// cout << v[input - 1] << "\n";
RészfeladatÖsszpontTesztVerdiktIdőMemória
base0/50
1Hibás válasz0/02ms1888 KiB
2Hibás válasz0/01ms1928 KiB
3Hibás válasz0/31ms1968 KiB
4Hibás válasz0/32ms1968 KiB
5Hibás válasz0/41ms1972 KiB
6Hibás válasz0/41ms1972 KiB
7Hibás válasz0/42ms1968 KiB
8Hibás válasz0/41ms1972 KiB
9Hibás válasz0/41ms1964 KiB
10Hibás válasz0/41ms1968 KiB
11Hibás válasz0/41ms1964 KiB
12Hibás válasz0/42ms1968 KiB
13Hibás válasz0/42ms1968 KiB
14Hibás válasz0/41ms1964 KiB
15Hibás válasz0/21ms1964 KiB
16Hibás válasz0/21ms1964 KiB