CSES - Datatähti 2022 alku - Results
Submission details
Task:Spiraali
Sender:eerosahlberg
Submission time:2021-10-13 09:11:40 +0300
Language:CPython3
Status:READY
Result:15
Feedback
groupverdictscore
#1ACCEPTED15
#20
#30
Test results
testverdicttimegroup
#1ACCEPTED0.03 s1details
#20.03 s2details
#30.03 s3details

Code

inp = input().split()

n = int(inp[0])
t = int(inp[1])

kierros = 0
value = 0

c = []





for i in range(t):
    cords = input().split()
    

    y = int(cords[0])
    x = int(cords[1])

    if(x<=n/2 and y>=x and y <= n-x+1):
        kierros = x
        
        if(kierros!=1):
            value = (kierros-1)*4*(n-1)-(kierros-2)*8 + (y-x+1)
        else:
            value = (y-x+1)
    elif(x>n/2 and y>=n-x+1 and y <= x):
        kierros = n-x+1
        
        if(kierros!=1):
            value = (kierros-1)*4*(n-1)-(kierros-2)*8 + (n-2*(kierros-1)) + ((n-2*(kierros-1))-1) + (n-y-(kierros-1))
        else:
            value = n + (n-1) + (n-y) 
    elif(y<=n/2):
        kierros = y
        
        if(kierros!=1):
            value = (kierros-1)*4*(n-1)-(kierros-2)*8 + (n-2*(kierros-1)) + 2*((n-2*(kierros-1))-1) + (n-x-y+1)
        else:
            value = n + 2*(n-1) + (n-x) 
    else:
        kierros = n-y+1
        
        if(kierros!=1):
            value = (kierros-1)*4*(n-1)-(kierros-2)*8 + (n-2*(kierros-1)) - ((n-x+1)-y)
        else:
            value=n-((n-x+1)-y)

    if(kierros <= 3):      
        print(value)
    elif(kierros == 4):
        print(value-8)
    else:
        print(value-24)
    
    

    

    





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:

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

correct output
773533
312166
206053
200080
593922
...

user output
1044949
340030
217053
210256
722778
...

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
690611871887141674
1638454347798170473
1026098781404448296
412631164917622006
1497597300494598947
...