Order book Yuriy Lyfenko

Simulate a sell-side order book and calculate the cost of a final purchase as fast as possible.

Input

1,000,000 order updates on STDIN, one per line:

  • + <price> <size> – add a new sell order
  • - <position> – delete the order at the given position
  • = <size> – buy <size> shares from the top of the order book

After all updates are processed, buy 1,000 shares from the top of the order book.

Output

Print the total cost of the final 1,000-share purchase to STDOUT.

Order Book Rules

Orders are sorted by price ascending (lower is better). Orders at the same price are sorted by arrival time (earlier first). Position 0 is the best (lowest-price) offer.

The = (buy) operation consumes shares starting from position 0. If an order is fully consumed, it is removed from the book.

Example

Input Order book state
+ 1137 100 (1137,100)
+ 1130 10 (1130,10), (1137,100)
+ 1130 50 (1130,10), (1130,50), (1137,100)
- 0 (1130,50), (1137,100)
+ 1150 200 (1130,50), (1137,100), (1150,200)
= 200 (1150,150)

Total cost of the last buy: 50 * 1130 + 100 * 1137 + 50 * 1150.

Back to listOct 16, 2024 13:19@drytecc@dryteccError
Source Code

Source code access is restricted. Log in to request access.

Challenge History

No challenges yet.

Run Statistics
#DateScoreWall TimeCPU UserCPU SystemMemoryError
1Oct 16, 2024 13:1900000Error: expected "1439422 ", got "1434762 "
2Oct 16, 2024 13:1900000Error: expected "1012366 ", got "1030613 "
3Oct 16, 2024 13:1900000Error: expected "2077153 ", got "2076455 "
4Oct 16, 2024 13:1900000Error: expected "930818 ", got "945066 "
5Oct 16, 2024 13:1900000Error: expected "1536833 ", got "1534841 "
6Oct 16, 2024 13:1900000Error: expected "787944 ", got "790244 "
7Oct 16, 2024 13:1900000Error: expected "1466815 ", got "1525069 "
8Oct 16, 2024 13:1900000Error: expected "1151981 ", got "1151537 "
9Oct 16, 2024 13:1900000Error: expected "748146 ", got "748357 "
10Oct 16, 2024 13:2000000Error: expected "1511421 ", got "1512024 "
11Oct 16, 2024 13:2000000Error: expected "785676 ", got "785659 "
12Oct 16, 2024 13:2000000Error: expected "2687921 ", got "2689015 "
13Oct 16, 2024 13:2000000Error: expected "1609909 ", got "1689619 "
14Oct 16, 2024 13:2000000Error: expected "1415999 ", got "1453095 "
15Oct 16, 2024 13:2000000Error: expected "850674 ", got "849276 "
16Oct 16, 2024 13:2000000Error: expected "780456 ", got "801181 "
17Oct 16, 2024 13:2000000Error: expected "1571938 ", got "1615136 "
18Oct 16, 2024 13:2000000Error: expected "2923174 ", got "2923070 "
19Oct 16, 2024 13:2000000Error: expected "736164 ", got "733040 "
20Oct 16, 2024 13:2000000Error: expected "2450972 ", got "2501283 "
21Oct 16, 2024 13:2000000Error: expected "1017494 ", got "1017049 "
22Oct 16, 2024 13:2000000Error: expected "1633183 ", got "1629422 "
23Oct 16, 2024 13:2000000Error: expected "930313 ", got "930495 "
24Oct 16, 2024 13:2000000Error: expected "992092 ", got "1009409 "
25Oct 16, 2024 13:2000000Error: expected "1805802 ", got "1892534 "
26Oct 16, 2024 13:2000000Error: expected "2190016 ", got "2190610 "
27Oct 16, 2024 13:2000000Error: expected "1192211 ", got "1191635 "
28Oct 16, 2024 13:2000000Error: expected "1190214 ", got "1189752 "
29Oct 16, 2024 13:2000000Error: expected "699966 ", got "687658 "
30Oct 16, 2024 13:2100000Error: expected "1922888 ", got "1923220 "
31Oct 16, 2024 13:2100000Error: expected "2438001 ", got "2534346 "
32Oct 16, 2024 13:2100000Error: expected "2053898 ", got "2105009 "
33Oct 16, 2024 13:2100000Error: expected "971367 ", got "990853 "
34Oct 16, 2024 13:2100000Error: expected "2714960 ", got "2718085 "
35Oct 16, 2024 13:2100000Error: expected "1333501 ", got "1354330 "
36Oct 16, 2024 13:2100000Error: expected "1365164 ", got "1364650 "
37Oct 16, 2024 13:2100000Error: expected "2158453 ", got "2159885 "
38Oct 16, 2024 13:2100000Error: expected "861780 ", got "861033 "
39Oct 16, 2024 13:2100000Error: expected "1677345 ", got "1775942 "
40Oct 16, 2024 13:2100000Error: expected "1118380 ", got "1118175 "
41Oct 16, 2024 13:2100000Error: expected "3504589 ", got "3506188 "
42Oct 16, 2024 13:2100000Error: expected "1665962 ", got "1664660 "
43Oct 16, 2024 13:2100000Error: expected "1007203 ", got "1010503 "
44Oct 16, 2024 13:2100000Error: expected "2227289 ", got "2228477 "
45Oct 16, 2024 13:2100000Error: expected "1060123 ", got "1078552 "
46Oct 16, 2024 13:2100000Error: expected "1700472 ", got "1699692 "
47Oct 16, 2024 13:2100000Error: expected "2333240 ", got "2334023 "
48Oct 16, 2024 13:2100000Error: expected "2277425 ", got "2290940 "
49Oct 16, 2024 13:2100000Error: expected "3588241 ", got "3707006 "
50Oct 16, 2024 13:2100000Error: expected "1074194 ", got "1125258 "
51Oct 16, 2024 13:2400000Error: expected "875882 ", got "881872 "
52Oct 16, 2024 13:2400000Error: expected "933001 ", got "933079 "
53Oct 16, 2024 13:2400000Error: expected "1004804 ", got "1004752 "
54Oct 16, 2024 13:2400000Error: expected "794710 ", got "794655 "
55Oct 16, 2024 13:2500000Error: expected "1928966 ", got "1929129 "
56Oct 16, 2024 13:2500000Error: expected "1291725 ", got "1297124 "
57Oct 16, 2024 13:2500000Error: expected "1395573 ", got "1500617 "
58Oct 16, 2024 13:2500000Error: expected "2439045 ", got "2436932 "
59Oct 16, 2024 13:2500000Error: expected "1101044 ", got "1099701 "
60Oct 16, 2024 13:2500000Error: expected "1579610 ", got "1582196 "
61Oct 16, 2024 13:2500000Error: expected "999033 ", got "1018124 "
62Oct 16, 2024 13:2500000Error: expected "1846960 ", got "1848607 "
63Oct 16, 2024 13:2500000Error: expected "3518650 ", got "3542538 "
64Oct 16, 2024 13:2500000Error: expected "1734474 ", got "1738639 "
65Oct 16, 2024 13:2500000Error: expected "772754 ", got "780151 "
66Oct 16, 2024 13:2500000Error: expected "780709 ", got "789629 "
67Oct 16, 2024 13:2500000Error: expected "2086510 ", got "2092886 "
68Oct 16, 2024 13:2500000Error: expected "852674 ", got "852719 "
69Oct 16, 2024 13:2500000Error: expected "732400 ", got "732352 "
70Oct 16, 2024 13:2500000Error: expected "1762726 ", got "1764692 "
71Oct 16, 2024 13:2500000Error: expected "774640 ", got "990305 "
72Oct 16, 2024 13:2500000Error: expected "1138980 ", got "1138716 "
73Oct 16, 2024 13:2500000Error: expected "1226361 ", got "1641328 "
74Oct 16, 2024 13:2500000Error: expected "2186141 ", got "2185131 "
75Oct 16, 2024 13:2500000Error: expected "802459 ", got "802068 "
76Oct 16, 2024 13:2500000Error: expected "1004941 ", got "1006460 "
77Oct 16, 2024 13:2500000Error: expected "2312472 ", got "2418369 "
78Oct 16, 2024 13:2500000Error: expected "1861626 ", got "1900875 "
79Oct 16, 2024 13:2500000Error: expected "1612724 ", got "1612769 "
80Oct 16, 2024 13:2600000Error: expected "1183926 ", got "1186491 "
81Oct 16, 2024 13:2600000Error: expected "2181423 ", got "2193082 "
82Oct 16, 2024 13:2600000Error: expected "884791 ", got "884333 "
83Oct 16, 2024 13:2600000Error: expected "3361970 ", got "3354728 "
84Oct 16, 2024 13:2600000Error: expected "2387379 ", got "2385354 "
85Oct 16, 2024 13:2600000Error: expected "3023104 ", got "3021754 "
86Oct 16, 2024 13:2600000Error: expected "1429708 ", got "1429742 "
87Oct 16, 2024 13:2600000Error: expected "726692 ", got "726542 "
88Oct 16, 2024 13:2600000Error: expected "941390 ", got "938493 "
89Oct 16, 2024 13:2600000Error: expected "2072624 ", got "2100750 "
90Oct 16, 2024 13:2600000Error: expected "1208752 ", got "1210708 "
91Oct 16, 2024 13:2700000Error: expected "712154 ", got "844179 "
92Oct 16, 2024 13:2700000Error: expected "733928 ", got "735727 "
93Oct 16, 2024 13:2700000Error: expected "2693628 ", got "2693754 "
94Oct 16, 2024 13:2700000Error: expected "847574 ", got "865899 "
95Oct 16, 2024 13:2700000Error: expected "785354 ", got "785370 "
96Oct 16, 2024 13:2700000Error: expected "1070288 ", got "1072360 "
97Oct 16, 2024 13:2700000Error: expected "784347 ", got "784450 "
98Oct 16, 2024 13:2700000Error: expected "1111656 ", got "1112625 "
99Oct 16, 2024 13:2700000Error: expected "1380352 ", got "1381357 "
100Oct 16, 2024 13:2700000Error: expected "1131076 ", got "1132896 "
101Oct 16, 2024 13:2900000Error: expected "751531 ", got "756983 "
102Oct 16, 2024 13:2900000Error: expected "1607180 ", got "1607259 "
103Oct 16, 2024 13:2900000Error: expected "1408778 ", got "1412574 "
104Oct 16, 2024 13:2900000Error: expected "710579 ", got "716837 "
105Oct 16, 2024 13:2900000Error: expected "1335021 ", got "1337055 "
106Oct 16, 2024 13:2900000Error: expected "1857440 ", got "1858038 "
107Oct 16, 2024 13:2900000Error: expected "1212630 ", got "1219020 "
108Oct 16, 2024 13:2900000Error: expected "1565266 ", got "1572659 "
109Oct 16, 2024 13:2900000Error: expected "1154576 ", got "1154685 "
110Oct 16, 2024 13:2900000Error: expected "1989674 ", got "1991670 "
111Oct 16, 2024 13:2900000Error: expected "1383187 ", got "1400432 "
112Oct 16, 2024 13:2900000Error: expected "1510380 ", got "1503521 "
113Oct 16, 2024 13:3000000Error: expected "3571198 ", got "3568702 "
114Oct 16, 2024 13:3000000Error: expected "1479604 ", got "1492700 "
115Oct 16, 2024 13:3000000Error: expected "819465 ", got "819860 "
116Oct 16, 2024 13:3000000Error: expected "2260482 ", got "2285719 "
117Oct 16, 2024 13:3000000Error: expected "2338364 ", got "2347692 "
118Oct 16, 2024 13:3000000Error: expected "1077648 ", got "1074333 "
119Oct 16, 2024 13:3000000Error: expected "1070292 ", got "1075813 "
120Oct 16, 2024 13:3000000Error: expected "1321665 ", got "1314350 "
121Oct 16, 2024 13:3000000Error: expected "838323 ", got "838403 "
122Oct 16, 2024 13:3000000Error: expected "773785 ", got "806418 "
123Oct 16, 2024 13:3000000Error: expected "1576555 ", got "1585806 "
124Oct 16, 2024 13:3000000Error: expected "1027811 ", got "1060236 "
125Oct 16, 2024 13:3100000Error: expected "760754 ", got "776958 "
126Oct 16, 2024 13:3100000Error: expected "1005064 ", got "1067129 "
127Oct 16, 2024 13:3200000Error: expected "2139825 ", got "2293552 "
128Oct 16, 2024 13:3200000Error: expected "949745 ", got "949647 "
129Oct 16, 2024 13:3200000Error: expected "1585728 ", got "1586303 "
130Oct 16, 2024 13:3200000Error: expected "848634 ", got "848630 "
131Oct 16, 2024 13:3200000Error: expected "2394348 ", got "2393496 "
132Oct 16, 2024 13:3200000Error: expected "1052163 ", got "1079765 "
133Oct 16, 2024 13:3200000Error: expected "1204125 ", got "1203740 "
134Oct 16, 2024 13:3200000Error: expected "1695815 ", got "1697762 "
135Oct 16, 2024 13:3200000Error: expected "1396887 ", got "1397074 "
136Oct 16, 2024 13:3200000Error: expected "1702561 ", got "1721628 "
137Oct 16, 2024 13:3200000Error: expected "2707896 ", got "2705965 "
138Oct 16, 2024 13:3200000Error: expected "1139245 ", got "1138138 "
139Oct 16, 2024 13:3200000Error: expected "686847 ", got "684399 "
140Oct 16, 2024 13:3200000Error: expected "710518 ", got "706716 "
141Oct 16, 2024 13:3300000Error: expected "1487370 ", got "1487341 "
142Oct 16, 2024 13:3300000Error: expected "1098780 ", got "1103813 "
143Oct 16, 2024 13:3300000Error: expected "2020266 ", got "2020970 "
144Oct 16, 2024 13:3300000Error: expected "3037958 ", got "3037441 "
145Oct 16, 2024 13:3300000Error: expected "791458 ", got "833581 "
146Oct 16, 2024 13:3300000Error: expected "923800 ", got "923571 "