| Task: | Card game |
| Sender: | ileska |
| Submission time: | 2025-09-11 18:14:56 +0300 |
| Language: | Python3 (CPython3) |
| Status: | READY |
| Result: | ACCEPTED |
| test | verdict | time | |
|---|---|---|---|
| #1 | ACCEPTED | 0.02 s | details |
| #2 | ACCEPTED | 0.02 s | details |
| #3 | ACCEPTED | 0.02 s | details |
| #4 | ACCEPTED | 0.02 s | details |
| #5 | ACCEPTED | 0.02 s | details |
| #6 | ACCEPTED | 0.03 s | details |
| #7 | ACCEPTED | 0.14 s | details |
| #8 | ACCEPTED | 1.15 s | details |
| #9 | ACCEPTED | 1.14 s | details |
| #10 | ACCEPTED | 1.15 s | details |
| #11 | ACCEPTED | 0.02 s | details |
| #12 | ACCEPTED | 0.02 s | details |
| #13 | ACCEPTED | 0.02 s | details |
| #14 | ACCEPTED | 1.22 s | details |
| #15 | ACCEPTED | 1.09 s | details |
Code
from functools import cache
from time import time
from math import ceil
@cache
def findMaxBuildIn(start, end, cards):
# print(start,end)
suMax = 0
for ii in range(start, end-3+1):
su = cards[ii+1]
if start+3-1 < ii:
ret = findMaxBuildIn(start, ii, cards)
su += ret
# print("LeftCut", start, ii, ret)
if end-3-3+1 > ii:
ret = findMaxBuildIn(ii+3, end, cards)
su += ret
# print("RightCut", ii+3, end, ret)
if su > suMax:
# print("max",su, suMax)
suMax = su
return suMax
# @cache
def findMax(start, end, cards, myCache):
# print(start,end)
suMax = 0
for ii in range(start, end-3+1):
su = cards[ii+1]
if start+3-1 < ii:
ret = 0
if myCache[start][ii] !=-1: ret = myCache[start][ii]
else: ret = findMax(start, ii, cards, myCache)
su += ret
# print("LeftCut", start, ii, ret)
if end-3-3+1 > ii:
ret = 0
if myCache[ii+3][end] != -1: ret = myCache[ii+3][end]
else: ret = findMax(ii+3, end, cards, myCache)
su += ret
# print("RightCut", ii+3, end, ret)
if su > suMax:
# print("max",su, suMax)
suMax = su
myCache[start][end] = suMax
return suMax
def printCache(cach):
ma = ceil(max(max(cach))**(1/10))
for line in cach:
for ch in line:
print(f"{ch:2}", end=" ")
print()
def dp(endMax, cards):
if endMax < 3:
return 0
myCache = [-1 for _ in range(endMax-2)]
myCache[0] = cards[1]
for startLastSeg in range(1, endMax-2):
ma = 0
for ii in range(1, 3):
if startLastSeg >= ii:
if ma < myCache[startLastSeg-ii]:
ma = myCache[startLastSeg-ii]
if startLastSeg >= 3:
if ma < myCache[startLastSeg-3]+cards[startLastSeg+1]:
ma = myCache[startLastSeg-3]+cards[startLastSeg+1]
else:
if ma < cards[startLastSeg+1]:
ma = cards[startLastSeg+1]
myCache[startLastSeg] = ma
return myCache[-1]
cardCount = int(input())
cards = tuple([int(aa) for aa in input().split()])
# stupidBuildIn = findMaxBuildIn(0, cardCount, cards)
# t0 = time()
# myCache = [[-1 for _ in range(0,cardCount+1)] for _ in range(0,cardCount+1)]
# stupid = findMax(0, cardCount, cards, myCache)
t1 = time()
dpCount = dp(cardCount, cards)
t2 = time()
# print(stupid, dpCount)
print(dpCount)
# print(t1-t0,t2-t1)
# print(t2-t1)
# print(dpCount)
Test details
Test 1
Verdict: ACCEPTED
| input |
|---|
| 5 9 4 1 6 6 |
| correct output |
|---|
| 6 |
| user output |
|---|
| 6 |
Test 2
Verdict: ACCEPTED
| input |
|---|
| 6 5 6 2 4 10 1 |
| correct output |
|---|
| 16 |
| user output |
|---|
| 16 |
Test 3
Verdict: ACCEPTED
| input |
|---|
| 10 8 9 10 2 7 1 10 10 1 4 |
| correct output |
|---|
| 26 |
| user output |
|---|
| 26 |
Test 4
Verdict: ACCEPTED
| input |
|---|
| 100 1 8 8 5 7 10 9 4 8 10 6 3 8 7 ... |
| correct output |
|---|
| 243 |
| user output |
|---|
| 243 |
Test 5
Verdict: ACCEPTED
| input |
|---|
| 1000 10 7 5 6 5 2 5 3 2 2 1 6 8 7 8... |
| correct output |
|---|
| 2230 |
| user output |
|---|
| 2230 |
Test 6
Verdict: ACCEPTED
| input |
|---|
| 10000 9 1 8 2 6 5 1 3 3 10 6 3 9 3 1... |
| correct output |
|---|
| 22363 |
| user output |
|---|
| 22363 |
Test 7
Verdict: ACCEPTED
| input |
|---|
| 100000 5 5 4 6 8 7 9 6 3 2 5 8 7 3 5 ... |
| correct output |
|---|
| 226636 |
| user output |
|---|
| 226636 |
Test 8
Verdict: ACCEPTED
| input |
|---|
| 1000000 5 8 5 7 9 1 9 10 3 6 1 8 3 9 7... |
| correct output |
|---|
| 2259395 |
| user output |
|---|
| 2259395 |
Test 9
Verdict: ACCEPTED
| input |
|---|
| 1000000 4 5 3 5 4 3 6 7 10 6 3 9 7 9 1... |
| correct output |
|---|
| 2260761 |
| user output |
|---|
| 2260761 |
Test 10
Verdict: ACCEPTED
| input |
|---|
| 1000000 10 3 6 7 7 10 4 4 5 2 9 4 6 10... |
| correct output |
|---|
| 2260407 |
| user output |
|---|
| 2260407 |
Test 11
Verdict: ACCEPTED
| input |
|---|
| 3 87 3 123 |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 12
Verdict: ACCEPTED
| input |
|---|
| 2 175 95 |
| correct output |
|---|
| 0 |
| user output |
|---|
| 0 |
Test 13
Verdict: ACCEPTED
| input |
|---|
| 1 42 |
| correct output |
|---|
| 0 |
| user output |
|---|
| 0 |
Test 14
Verdict: ACCEPTED
| input |
|---|
| 1000000 1000 1000 1000 1000 1000 1000 ... |
| correct output |
|---|
| 333333000 |
| user output |
|---|
| 333333000 |
Test 15
Verdict: ACCEPTED
| input |
|---|
| 1000000 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 ... |
| correct output |
|---|
| 333333 |
| user output |
|---|
| 333333 |
