Task: | Kortit II |
Sender: | noitamonni |
Submission time: | 2024-11-02 11:20:34 +0200 |
Language: | Python3 (CPython3) |
Status: | READY |
Result: | 0 |
group | verdict | score |
---|---|---|
#1 | WRONG ANSWER | 0 |
#2 | WRONG ANSWER | 0 |
#3 | WRONG ANSWER | 0 |
#4 | WRONG ANSWER | 0 |
#5 | WRONG ANSWER | 0 |
test | verdict | time | group | |
---|---|---|---|---|
#1 | WRONG ANSWER | 0.02 s | 1, 2, 3, 4, 5 | details |
#2 | WRONG ANSWER | 0.22 s | 2, 3, 4, 5 | details |
#3 | TIME LIMIT EXCEEDED | -- | 3, 4, 5 | details |
#4 | TIME LIMIT EXCEEDED | -- | 4, 5 | details |
#5 | RUNTIME ERROR | 0.02 s | 5 | details |
#6 | RUNTIME ERROR | 0.02 s | 5 | details |
Code
from collections import deque from math import factorial import sys t = sys.stdin.readline() for line in sys.stdin.readlines(): n, a, b = [int(x) for x in line.split()] if a + b > n: print(0) continue elif (a == 0 and b != 0) or (b == 0 and a != 0): print(0) continue ties = n - a - b tot_cards2 = [x for x in range(1, n-ties+1)] valid_games = 0 pos_ties = int(factorial(n)/factorial(n-ties)) # all_pos = (factorial(n))**2 # all_pos_remaining = (factorial(n-ties))**2 def search(c1, cards2, p1, p2): if c1 == 0: if p1 == a and p2 == b: global valid_games valid_games += 1 else: for i in range(len(cards2)): cs2 = cards2[:] if len(cards2) == 0: break if cs2[i] == c1: continue else: c2 = cs2.pop(i) if c1 > c2: search(c1-1, cs2, p1+1, p2) elif c1 < c2: search(c1-1, cs2, p1, p2+1) if a == 0 and b == 0: print(pos_ties) continue if a == 1 or b == 1: valid_games = 1 else: search(n-ties, tot_cards2, 0, 0) total_amount = (valid_games*factorial((n-ties)))*(factorial(n)/factorial(n-ties))**2 print(int(total_amount % ((10**9)+7)))
Test details
Test 1
Group: 1, 2, 3, 4, 5
Verdict: WRONG ANSWER
input |
---|
54 4 4 0 3 1 3 3 2 2 4 0 4 ... |
correct output |
---|
0 0 0 0 0 ... |
user output |
---|
0 0 0 0 0 ... |
Test 2
Group: 2, 3, 4, 5
Verdict: WRONG ANSWER
input |
---|
284 6 1 0 5 0 2 7 1 5 7 7 5 ... |
correct output |
---|
0 0 35280 0 36720 ... |
user output |
---|
0 0 35280 0 36720 ... |
Test 3
Group: 3, 4, 5
Verdict: TIME LIMIT EXCEEDED
input |
---|
841 19 3 12 19 19 13 19 7 13 20 11 15 ... |
correct output |
---|
40291066 0 0 0 0 ... |
user output |
---|
(empty) |
Test 4
Group: 4, 5
Verdict: TIME LIMIT EXCEEDED
input |
---|
1000 15 12 6 7 1 6 44 4 26 6 6 5 ... |
correct output |
---|
0 5040 494558320 0 340694548 ... |
user output |
---|
(empty) |
Test 5
Group: 5
Verdict: RUNTIME ERROR
input |
---|
1000 892 638 599 966 429 655 1353 576 1140 1403 381 910 ... |
correct output |
---|
0 0 0 249098285 0 ... |
user output |
---|
0 0 0 |
Error:
Traceback (most recent call last): File "/box/input/code.py", line 21, in <module> pos_ties = int(factorial(n)/factorial(n-ties)) OverflowError: integer division result too large for a float
Test 6
Group: 5
Verdict: RUNTIME ERROR
input |
---|
1000 2000 1107 508 2000 1372 249 2000 588 65 2000 1739 78 ... |
correct output |
---|
750840601 678722180 744501884 159164549 868115056 ... |
user output |
---|
(empty) |
Error:
Traceback (most recent call last): File "/box/input/code.py", line 21, in <module> pos_ties = int(factorial(n)/factorial(n-ties)) OverflowError: integer division result too large for a float