CSES - Datatähti 2022 alku - Results
Submission details
Task:Spiraali
Sender:Kargeri
Submission time:2021-10-07 21:19:06 +0300
Language:C++11
Status:READY
Result:85
Feedback
groupverdictscore
#10
#2ACCEPTED20
#3ACCEPTED65
Test results
testverdicttimegroup
#10.01 s1details
#2ACCEPTED0.01 s2details
#3ACCEPTED0.01 s3details

Code

#include <iostream>
//#include <chrono>

using namespace std;

int main()
{
    long n, t, x, y, r, iar, b, ns;
	cin >> n;
	cin >> t;
    long results[1000];
    ns = n * n;
    //auto start = std::chrono::steady_clock::now();

	for (int j = 0; j < t; j++)
	{
        cin >> y;
        cin >> x;

        r = 0;
        if (y > x)
        {
            if (x <= n - y)
            {
                r = x;
            }
            else
            {
                r = n - y + 1;
            }
        }
        else
        {
            if (y <= n - x)
            {
                r = y;
            }
            else
            {
                r = n - x + 1;
            }
        }
        //cout << endl << "ring: " << r << endl;
                
        iar = n - (r - 1) * 2;
        b = ns - iar * iar + 1;
        if (x == 1 and y == 1)
        {
            results[j] = 1;
        }
        else if (x == r)
        {
            results[j] = b + y - r;
        }
        else if (y == n - r + 1)
        {
            results[j] = b + iar - 1 + x - r;
        }
        else if (x == n - r + 1)
        {
            results[j] = b + iar * 2 - 2 + n - y - r + 1;
        }
        else if (y == r)
        {
            results[j] = b + iar * 3 - 3 + n - x - r + 1;
        }
        else
        {
            cout << "umm.. error: x: " << x << " y: " << y << endl;
            cout << "ring: " << r << endl;
            cout << "begin: " << b << endl;
            return 1;
        } 
        if (results[j] == 37)
        {
            cout << endl << "debug" << endl;
            cout << "x: " << x << " y: " << y << endl << endl;
            cout << "ring: " << r << endl;
            cout << "begin: " << b << endl;
        }
	}


    for (int i = 0; i < t; i++)
    {
        cout << results[i] << endl;
    }


    //auto end = std::chrono::steady_clock::now();
    //std::chrono::duration<double> elapsed_seconds = end - start;
    //std::cout << "elapsed time to compute: " << elapsed_seconds.count() << "s\n";

    return 0;
} 

Test details

Test 1

Group: 1

Verdict:

input
10 100
1 1
1 2
1 3
1 4
...

correct output
1
36
35
34
33
...

user output

debug
x: 2 y: 2

ring: 2
...

Test 2

Group: 2

Verdict: ACCEPTED

input
1000 1000
371 263
915 322
946 880
53 738
...

correct output
773533
312166
206053
200080
593922
...

user output
773533
312166
206053
200080
593922
...

Test 3

Group: 3

Verdict: ACCEPTED

input
1000000000 1000
177757853 827347032
409613589 419171337
739269360 256524697
328695530 896842209
...

correct output
571375684522141210
967321186816598569
762879105851175000
370065046779516790
936897883750373771
...

user output
571375684522141210
967321186816598569
762879105851175000
370065046779516790
936897883750373771
...