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.

Date AuthorLanguageStatus Score
Dec 21, 2023 10:00DenisDenisRUSTrust-1.74.1Error
Dec 21, 2023 09:56DenisDenisRUSTrust-1.74.1Error
Dec 21, 2023 09:53DenisDenisRUSTrust-1.74.1Error
Dec 21, 2023 09:49DenisDenisRUSTrust-1.74.1Error
Dec 21, 2023 09:40DenisDenisRUSTrust-1.74.1Error
Dec 20, 2023 19:25Kenneth MaplesKenneth MaplesCPPg++9.3.0Success87,930+3.01 RP
Dec 20, 2023 15:24parastromparastromRUSTrust-1.74.0Error
Dec 20, 2023 15:20parastromparastromRUSTrust-1.74.0Error
Dec 18, 2023 00:28parastromparastromRUSTrust-1.74.0Error
Dec 18, 2023 00:27parastromparastromRUSTrust-1.74.0Error
Dec 18, 2023 00:26parastromparastromRUSTrust-1.74.0Error
Dec 18, 2023 00:24parastromparastromRUSTrust-1.74.0Error
Dec 18, 2023 00:14parastromparastromRUSTrust-1.74.0Error
Dec 18, 2023 00:14parastromparastromRUSTrust-1.74.0Error
Dec 18, 2023 00:09parastromparastromRUSTrust-1.74.0Error
Dec 18, 2023 00:08parastromparastromRUSTrust-1.74.0Error
Dec 17, 2023 06:20Kenneth MaplesKenneth MaplesCPPg++9.3.0Error
Dec 17, 2023 06:08Kenneth MaplesKenneth MaplesCPPg++9.3.0Success96,311
Dec 17, 2023 06:07Kenneth MaplesKenneth MaplesCPPg++9.3.0Success92,390
Dec 17, 2023 06:04Kenneth MaplesKenneth MaplesCPPg++9.3.0Success96,905
Dec 17, 2023 06:03Kenneth MaplesKenneth MaplesCPPg++9.3.0Success93,286
Dec 17, 2023 05:59Kenneth MaplesKenneth MaplesCPPg++9.3.0Success98,162
Dec 17, 2023 05:53Kenneth MaplesKenneth MaplesCPPg++9.3.0Error
Dec 17, 2023 05:45Kenneth MaplesKenneth MaplesCPPg++9.3.0Error
Dec 17, 2023 05:31Kenneth MaplesKenneth MaplesCPPg++9.3.0Success96,831
Dec 17, 2023 05:28Kenneth MaplesKenneth MaplesCPPg++9.3.0Success94,298
Dec 17, 2023 05:26Kenneth MaplesKenneth MaplesCPPg++9.3.0Success93,210
Dec 17, 2023 05:21Kenneth MaplesKenneth MaplesCPPg++9.3.0Success94,905
Dec 17, 2023 05:20Kenneth MaplesKenneth MaplesCPPg++9.3.0Success90,322+0.20 RP
Dec 17, 2023 05:19Kenneth MaplesKenneth MaplesCPPg++9.3.0Success90,488+7.54 RP
Dec 17, 2023 05:18Kenneth MaplesKenneth MaplesCPPg++9.3.0Error
Dec 16, 2023 18:24mebowlermebowlerGOgo1.21.5Error
Dec 15, 2023 16:07parastromparastromRUSTrust-1.74.0Error
Dec 15, 2023 16:06parastromparastromRUSTrust-1.74.0Error
Dec 15, 2023 15:01parastromparastromRUSTrust-1.74.0Error
Dec 15, 2023 14:57parastromparastromRUSTrust-1.74.0Success230,247+33.03 RP
Dec 15, 2023 14:54parastromparastromRUSTrust-1.74.0Error
Dec 15, 2023 14:47parastromparastromRUSTrust-1.74.0Error
Dec 15, 2023 14:45parastromparastromRUSTrust-1.74.0Error
Dec 15, 2023 14:27parastromparastromRUSTrust-1.74.0Error
Dec 15, 2023 14:24parastromparastromRUSTrust-1.74.0Error
Dec 15, 2023 14:23parastromparastromRUSTrust-1.74.0Error
Dec 15, 2023 14:21parastromparastromRUSTrust-1.74.0Error
Dec 15, 2023 14:20parastromparastromRUSTrust-1.74.0Error
Dec 15, 2023 14:19matsuoka-601matsuoka-601CPPclang++10.0.0Error
Dec 15, 2023 14:19parastromparastromRUSTrust-1.74.0Error
Dec 15, 2023 14:07parastromparastromRUSTrust-1.74.0Error
Dec 15, 2023 13:57parastromparastromRUSTrust-1.74.0Error
Dec 15, 2023 13:47parastromparastromRUSTrust-1.74.0Error
Dec 15, 2023 12:51parastromparastromRUSTrust-1.74.0Error
Dec 15, 2023 04:12parastromparastromCPPg++9.3.0Success2,271,416
Dec 14, 2023 06:49Sergey StreminSergey StreminRUSTrust-1.74.0Success78,453
Dec 14, 2023 06:46Sergey StreminSergey StreminRUSTrust-1.74.0Success76,096
Dec 13, 2023 20:23PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success424,195
Dec 13, 2023 18:55PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success325,488
Dec 13, 2023 18:11PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success122,188
Dec 13, 2023 07:31mebowlermebowlerGOgo1.21.5Error
Dec 13, 2023 07:29mebowlermebowlerGOgo1.21.5Error
Dec 13, 2023 07:27mebowlermebowlerGOgo1.21.5Error
Dec 13, 2023 07:19mebowlermebowlerGOgo1.21.5Error
Dec 13, 2023 07:16mebowlermebowlerGOgo1.21.5Error
Dec 13, 2023 07:14mebowlermebowlerGOgo1.21.5Error
Dec 12, 2023 22:34mebowlermebowlerGOgo1.21.5Error
Dec 12, 2023 08:47matsuoka-601matsuoka-601CPPclang++10.0.0Error
Dec 12, 2023 08:45matsuoka-601matsuoka-601CPPclang++10.0.0Success40,312+0.90 RP
Dec 12, 2023 08:38matsuoka-601matsuoka-601CPPclang++10.0.0Error
Dec 12, 2023 08:34matsuoka-601matsuoka-601CPPclang++10.0.0Error
Dec 12, 2023 03:57PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success122,476
Dec 12, 2023 02:32PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success119,145
Dec 12, 2023 02:32PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success119,088
Dec 12, 2023 02:31PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success133,829
Dec 12, 2023 02:30PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success135,443
Dec 12, 2023 02:30PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success135,697
Dec 12, 2023 01:28PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success119,193
Dec 12, 2023 01:27PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success119,197
Dec 12, 2023 01:26PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success136,325
Dec 12, 2023 01:04PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success145,928
Dec 12, 2023 01:03PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success199,505
Dec 12, 2023 01:03PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Error
Dec 12, 2023 01:02PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Error
Dec 12, 2023 00:59PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Error
Dec 12, 2023 00:57PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Error
Dec 12, 2023 00:29PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Error
Dec 12, 2023 00:27PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Error
Dec 12, 2023 00:18PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success116,298
Dec 11, 2023 23:32PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success136,786
Dec 11, 2023 23:31PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Error
Dec 11, 2023 23:27PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Error
Dec 11, 2023 22:49PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Error
Dec 11, 2023 22:36PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success145,908
Dec 11, 2023 22:35PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success140,610
Dec 11, 2023 22:27PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success143,076
Dec 11, 2023 22:24PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success142,251
Dec 11, 2023 22:23PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success137,739
Dec 11, 2023 22:22PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success137,243
Dec 11, 2023 22:19PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Error
Dec 11, 2023 22:17PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Error
Dec 11, 2023 22:12PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success110,819+12.66 RP
Dec 11, 2023 22:11PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success136,036
Dec 11, 2023 22:10PiggyChan-2020PiggyChan-2020CPPclang++10.0.0Success128,898+0.33 RP