CSES - Datatähti 2017 loppu - Results
Submission details
Task:Jäätelö
Sender:inkeri
Submission time:2017-01-19 16:15:11 +0200
Language:Python3
Status:READY
Result:100
Feedback
groupverdictscore
#1ACCEPTED100
Test results
testverdicttime
#1ACCEPTED0.07 sdetails
#2ACCEPTED0.06 sdetails
#3ACCEPTED0.08 sdetails
#4ACCEPTED0.07 sdetails
#5ACCEPTED0.08 sdetails
#6ACCEPTED0.08 sdetails
#7ACCEPTED0.09 sdetails
#8ACCEPTED0.05 sdetails
#9ACCEPTED0.06 sdetails
#10ACCEPTED0.07 sdetails

Code

import sys

a = input().split(' ')
rahat = int(a[1])
a = int(a[0]) #jäätelöiden määrä
painot = []
hinnat = {}
for i in range(a):
	jatski = [int(b) for b in input().split(' ')]
	paino = jatski[1]
	hinta = jatski[0]
	if paino in painot:
		if hinnat[paino] > hinta:
			hinnat[paino] = hinta
	else:
		painot.append(paino)
		hinnat[paino] = hinta
a = len(painot)
painot.sort()
if a == 1 or 2 * hinnat[painot[-1]] <= rahat:
	print(2*painot[-1])
	sys.exit()
alku = a - 1
painavin = 0
while alku > -1:
	b = painot[alku]
	raja = rahat - hinnat[b]
	for i in range(alku, -1, -1):
		c = painot[i]
		if hinnat[c] <= raja:
			break
		elif i == 0:
			c = - b
	painavin = max(b + c, painavin)
	alku -= 1
print(painavin)

Test details

Test 1

Verdict: ACCEPTED

input
1 749
88 363

correct output
726

user output
726

Test 2

Verdict: ACCEPTED

input
2 902
968 550
152 228

correct output
456

user output
456

Test 3

Verdict: ACCEPTED

input
5 295
35 81
653 771
747 823
871 611
...

correct output
162

user output
162

Test 4

Verdict: ACCEPTED

input
10 272
38 13
114 420
42 344
942 307
...

correct output
840

user output
840

Test 5

Verdict: ACCEPTED

input
50 468
867 254
870 736
28 739
60 609
...

correct output
2000

user output
2000

Test 6

Verdict: ACCEPTED

input
100 739
395 712
476 916
102 614
312 533
...

correct output
1928

user output
1928

Test 7

Verdict: ACCEPTED

input
100 781
342 898
466 888
713 516
133 389
...

correct output
1894

user output
1894

Test 8

Verdict: ACCEPTED

input
100 297
423 506
135 31
279 441
362 969
...

correct output
1906

user output
1906

Test 9

Verdict: ACCEPTED

input
100 875
917 956
243 815
365 575
42 846
...

correct output
1960

user output
1960

Test 10

Verdict: ACCEPTED

input
100 651
963 307
169 423
172 150
779 998
...

correct output
1970

user output
1970