| Task: | Roller coaster |
| Sender: | aalto25i_004 |
| Submission time: | 2025-10-29 17:07:32 +0200 |
| Language: | Python3 (PyPy3) |
| Status: | READY |
| Result: | ACCEPTED |
| test | verdict | time | |
|---|---|---|---|
| #1 | ACCEPTED | 0.04 s | details |
| #2 | ACCEPTED | 0.04 s | details |
| #3 | ACCEPTED | 0.04 s | details |
| #4 | ACCEPTED | 0.04 s | details |
| #5 | ACCEPTED | 0.04 s | details |
| #6 | ACCEPTED | 0.04 s | details |
| #7 | ACCEPTED | 0.04 s | details |
| #8 | ACCEPTED | 0.04 s | details |
| #9 | ACCEPTED | 0.04 s | details |
| #10 | ACCEPTED | 0.04 s | details |
| #11 | ACCEPTED | 0.04 s | details |
| #12 | ACCEPTED | 0.04 s | details |
Code
from math import gcd
def judge(segments, initial_speed):
speed_num = initial_speed
speed_den = 1
happy_count = 0
for p, r, a, f in segments:
if speed_num < r * speed_den:
return False, 0
if speed_num >= p * speed_den:
happy_count += 1
speed_num = speed_num * (100 - f) - a * speed_den * 100
speed_den = speed_den * 100
g = gcd(abs(speed_num), speed_den)
speed_num //= g
speed_den //= g
return True, happy_count
def Roller_coaster():
n = int(input())
segments = []
for _ in range(n):
p, r, a, f = map(int, input().split())
segments.append((p, r, a, f))
left, right = 0, 10**26
while left < right:
mid = (left + right) // 2
can_complete, happy_count = judge(segments, mid)
if can_complete and happy_count >= (n + 1) // 2:
right = mid
else:
left = mid + 1
print(left)
if __name__ == "__main__":
Roller_coaster()Test details
Test 1
Verdict: ACCEPTED
| input |
|---|
| 3
1000 5 5 0 20 20 20 50 50 50 0 99 |
| correct output |
|---|
| 145 |
| user output |
|---|
| 145 |
Test 2
Verdict: ACCEPTED
| input |
|---|
| 10
1000000 1000000 1000000 99 1000000 1000000 1000000 99 1000000 1000000 1000000 99 1000000 1000000 1000000 99 ... |
| correct output |
|---|
| 2010101010101010100000000 |
| user output |
|---|
| 2010101010101010100000000 |
Test 3
Verdict: ACCEPTED
| input |
|---|
| 7
794772 933488 441001 5 271493 536110 509532 51 962838 821872 870163 38 499748 375441 611720 27 ... |
| correct output |
|---|
| 19316405 |
| user output |
|---|
| 19316405 |
Test 4
Verdict: ACCEPTED
| input |
|---|
| 3
596853 888598 841235 97 66172 267459 123646 63 797926 471325 495185 83 |
| correct output |
|---|
| 81642158 |
| user output |
|---|
| 81642158 |
Test 5
Verdict: ACCEPTED
| input |
|---|
| 1
96033 88994 378596 21 |
| correct output |
|---|
| 96033 |
| user output |
|---|
| 96033 |
Test 6
Verdict: ACCEPTED
| input |
|---|
| 4
621429 570665 136758 47 960437 633256 497081 80 609067 68711 635017 1 952965 878149 492025 33 |
| correct output |
|---|
| 19366822 |
| user output |
|---|
| 19366822 |
Test 7
Verdict: ACCEPTED
| input |
|---|
| 4
318031 108177 756250 50 502140 162500 94476 8 20779 421098 576089 37 839335 802331 61705 28 |
| correct output |
|---|
| 6474336 |
| user output |
|---|
| 6474336 |
Test 8
Verdict: ACCEPTED
| input |
|---|
| 10
267853 777820 375951 88 988230 882388 775839 83 967127 555787 30414 59 813651 989181 261150 83 ... |
| correct output |
|---|
| 114240784216 |
| user output |
|---|
| 114240784216 |
Test 9
Verdict: ACCEPTED
| input |
|---|
| 10
861881 84483 508595 97 274330 38611 473 18 695015 614973 493097 97 770531 391287 334900 98 ... |
| correct output |
|---|
| 26667465547194 |
| user output |
|---|
| 26667465547194 |
Test 10
Verdict: ACCEPTED
| input |
|---|
| 6
993908 158176 414002 83 50631 75954 861168 68 98702 383452 611097 7 953893 532084 225127 4 ... |
| correct output |
|---|
| 46921821 |
| user output |
|---|
| 46921821 |
Test 11
Verdict: ACCEPTED
| input |
|---|
| 4
388404 393603 132467 24 739054 45905 89323 17 259460 850672 530957 26 420175 673047 31765 58 |
| correct output |
|---|
| 2895218 |
| user output |
|---|
| 2895218 |
Test 12
Verdict: ACCEPTED
| input |
|---|
| 8
643002 391445 280110 17 195187 908655 709512 0 354760 527205 486247 77 84740 350249 581194 78 ... |
| correct output |
|---|
| 250399569 |
| user output |
|---|
| 250399569 |
