CSES - DatatÃ¤hti 2022 alku - Results
 Task: Spiraali (Spiral) Sender: Kargeri Submission time: 2021-10-07 20:57:14 Language: C++11 Status: READY Result: 0
Feedback
groupverdictscore
#10
#20
#30
Test results
testverdicttimegroup
#10.01 s1details
#20.01 s2details
#30.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;

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;
}
}
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;
return 1;
}
}

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

//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
umm.. error: x: 5 y: 6

#### Test 2

Group: 2

Verdict:

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

correct output
773533
312166
206053
200080
593922
...

user output
umm.. error: x: 322 y: 915

#### Test 3

Group: 3

Verdict:

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

correct output
571375684522141210
967321186816598569
762879105851175000
370065046779516790
936897883750373771
...

user output
umm.. error: x: 454716447 y: 7...