CSES - Datatähti 2022 alku - Results
Submission details
Task:Spiraali
Sender:Luukasa
Submission time:2021-10-06 00:12:23 +0300
Language:C++17
Status:READY
Result:35
Feedback
groupverdictscore
#1ACCEPTED15
#2ACCEPTED20
#30
Test results
testverdicttimegroup
#1ACCEPTED0.01 s1details
#2ACCEPTED0.01 s2details
#3--3details

Compiler report

input/code.cpp: In function 'int main()':
input/code.cpp:48:1: warning: label 'next' defined but not used [-Wunused-label]
 next:
 ^~~~
input/code.cpp:9:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  scanf("%d %d", &n, &t);
  ~~~~~^~~~~~~~~~~~~~~~~
input/code.cpp:13:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   scanf("%d %d", &y, &x);
   ~~~~~^~~~~~~~~~~~~~~~~

Code

#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;

int main()
{
	int n, t, sum;
	scanf("%d %d", &n, &t);
	for(int i = 0; i < t; ++i)
	{
		int y, x, a;
		scanf("%d %d", &y, &x);
		sum = 1;
		int tox = min(n+1-x, n+1-y);
		int minxy = min(x, y);
		for(int j = 0; j < min(tox, minxy)-1; ++j)
		{
			sum+=4*(n-(2*j+1));
		}
		int xdiff = x-min(tox, minxy);
		int ydiff = y-min(tox, minxy);
		int sidelength = n-(2*(min(tox, minxy)-1));
		//printf("Xdiff: %d, Ydiff: %d, SL: %d\n", xdiff, ydiff, sidelength);
		if(ydiff == 0 && xdiff != 0)
		{
			a = sum+3*(sidelength-1)+(sidelength-1-xdiff);
		}
		else if(ydiff != 0 && xdiff == 0)
		{
			a = sum+ydiff;
		}
		else if(ydiff != 0 && xdiff != 0)
		{
			if(xdiff == sidelength-1)
			{
				a = sum+2*xdiff+(sidelength-1-ydiff);
			}
			else
			{
				a = sum+ydiff+xdiff;
			}
		}
		else
		{
			a = sum;
		}
next:
		printf("%d\n", a);
	}
	return 0;
}

Test details

Test 1

Group: 1

Verdict: ACCEPTED

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

correct output
1
36
35
34
33
...

user output
1
36
35
34
33
...

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:

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

correct output
571375684522141210
967321186816598569
762879105851175000
370065046779516790
936897883750373771
...

user output
(empty)