4592021-11-03 16:43:21TSomaToronyépítés (1,1,3,3)cpp11Wrong answer 26/50101ms2016 KiB
#include <iostream>

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



    int N;
    std::cin >> N;

    if (N > 50) {

        //std::vector<int> v(N+1);
        int v[4];

        v[0] = 1;
        v[1] = 2;
        v[2] = 4;
        v[3] = 0;

        int a, b, c, j = 3;

        for (size_t i = 3; i < N + 1; i++)
        {
            if (j > 3)
                j = 0;

            c = j;
            a = c - 1;
            b = c - 3;

            if (b < 0) {
                b += 4;
                if (a < 0)
                    a = 3;
            }

            v[c] = (2 * v[a] + 2 * v[b]);

            if (v[c] > 20210108)
                v[c] %= 20210108;

            j++;

            std::cout << v[c] << ", ";
        }

        std::cout << v[N % 4];
    }
    else
    {
        int v[] = { 1, 2, 4, 10, 24, 56, 132, 312, 736, 1736, 4096, 9664, 22800, 53792, 126912, 299424, 706432, 1666688, 3932224, 9277312, 1677892, 11220232, 574872, 4505528, 11241412, 3422460, 15855976, 13774560, 14183932, 19659600, 6237996, 423640, 19956372, 11968520, 4574212, 8640952, 798728, 10745880, 18563556, 18514460, 18100464, 12697716, 1794028, 19578876, 3922860, 11433776, 1394980, 10635680, 3718696, 10227352, 1305848, 10049088 };
        std::cout << v[N];
    }
}
SubtaskSumTestVerdictTimeMemory
base26/50
1Accepted0/02ms1820 KiB
2Wrong answer0/01ms1852 KiB
3Accepted3/31ms1900 KiB
4Accepted3/31ms1900 KiB
5Accepted4/41ms1900 KiB
6Accepted4/41ms1904 KiB
7Wrong answer0/4101ms1996 KiB
8Wrong answer0/414ms1996 KiB
9Accepted4/41ms1920 KiB
10Accepted4/41ms1936 KiB
11Wrong answer0/419ms1984 KiB
12Wrong answer0/4101ms2008 KiB
13Wrong answer0/489ms2000 KiB
14Wrong answer0/435ms2016 KiB
15Accepted2/21ms1932 KiB
16Accepted2/22ms1940 KiB