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 16, 2025 23:17HattonuriHattonuriCPPg++13.3.0Success40,743
Dec 16, 2025 23:08HattonuriHattonuriCPPg++13.3.0Success42,097
Dec 16, 2025 23:07HattonuriHattonuriCPPg++13.3.0Success41,810
Dec 16, 2025 23:05HattonuriHattonuriCPPg++13.3.0Success39,809
Dec 16, 2025 23:05HattonuriHattonuriCPPg++13.3.0Success40,553
Dec 16, 2025 23:04HattonuriHattonuriCPPg++13.3.0Success41,784
Dec 16, 2025 22:29HattonuriHattonuriCPPg++13.3.0Success42,990
Dec 16, 2025 22:22HattonuriHattonuriCPPg++13.3.0Success42,138
Dec 16, 2025 22:19HattonuriHattonuriCPPg++13.3.0Success42,260
Dec 16, 2025 22:07HattonuriHattonuriCPPg++13.3.0Success42,178
Dec 16, 2025 22:06HattonuriHattonuriCPPg++13.3.0Success42,429
Dec 16, 2025 22:04HattonuriHattonuriCPPg++13.3.0Success42,316
Dec 16, 2025 22:04HattonuriHattonuriCPPg++13.3.0Error
Dec 16, 2025 21:59HattonuriHattonuriCPPg++13.3.0Success42,148
Dec 16, 2025 21:59HattonuriHattonuriCPPg++13.3.0Success40,834
Dec 16, 2025 21:57HattonuriHattonuriCPPg++13.3.0Success43,050
Dec 16, 2025 21:56HattonuriHattonuriCPPg++13.3.0Success42,064
Dec 16, 2025 20:11HattonuriHattonuriCPPg++13.3.0Success41,953
Dec 16, 2025 20:10HattonuriHattonuriCPPg++13.3.0Success42,247
Dec 16, 2025 20:09HattonuriHattonuriCPPg++13.3.0Success42,941
Dec 16, 2025 19:52HattonuriHattonuriCPPg++13.3.0Success43,283
Dec 16, 2025 19:52HattonuriHattonuriCPPg++13.3.0Error
Dec 16, 2025 19:50HattonuriHattonuriCPPg++13.3.0Success45,719
Dec 16, 2025 19:44HattonuriHattonuriCPPg++13.3.0Success41,193
Dec 16, 2025 19:43HattonuriHattonuriCPPg++13.3.0Error
Dec 16, 2025 19:42HattonuriHattonuriCPPg++13.3.0Success41,705
Dec 16, 2025 19:40HattonuriHattonuriCPPg++13.3.0Success42,400
Dec 16, 2025 19:39HattonuriHattonuriCPPg++13.3.0Success41,547
Dec 16, 2025 19:36HattonuriHattonuriCPPg++13.3.0Success47,522
Dec 16, 2025 18:19HattonuriHattonuriCPPg++13.3.0Success44,905
Dec 16, 2025 18:10HattonuriHattonuriCPPg++13.3.0Success41,586
Dec 16, 2025 18:04HattonuriHattonuriCPPg++13.3.0Success47,200
Dec 16, 2025 18:03HattonuriHattonuriCPPg++13.3.0Success41,428
Dec 16, 2025 17:56HattonuriHattonuriCPPg++13.3.0Success45,395
Dec 16, 2025 17:56HattonuriHattonuriCPPg++13.3.0Success44,941
Dec 16, 2025 17:50HattonuriHattonuriCPPg++13.3.0Success45,255
Dec 16, 2025 17:50HattonuriHattonuriCPPg++13.3.0Success44,122
Dec 16, 2025 17:49HattonuriHattonuriCPPg++13.3.0Error
Dec 16, 2025 17:33HattonuriHattonuriCPPg++13.3.0Error
Dec 16, 2025 17:31HattonuriHattonuriCPPg++13.3.0Error
Dec 16, 2025 17:16HattonuriHattonuriCPPg++13.3.0Success47,662
Dec 16, 2025 05:01HattonuriHattonuriCPPg++13.3.0Success42,505
Dec 16, 2025 04:59HattonuriHattonuriCPPg++13.3.0Success42,664
Dec 16, 2025 04:59HattonuriHattonuriCPPg++13.3.0Success41,926
Dec 16, 2025 04:57HattonuriHattonuriCPPg++13.3.0Success40,881
Dec 16, 2025 04:55HattonuriHattonuriCPPg++13.3.0Error
Dec 16, 2025 04:54HattonuriHattonuriCPPg++13.3.0Success42,226
Dec 16, 2025 04:48HattonuriHattonuriCPPg++13.3.0Success41,260
Dec 16, 2025 04:46HattonuriHattonuriCPPg++13.3.0Success42,029
Dec 16, 2025 04:45HattonuriHattonuriCPPg++13.3.0Success41,645
Dec 16, 2025 04:06HattonuriHattonuriCPPg++13.3.0Success41,941
Dec 16, 2025 04:06HattonuriHattonuriCPPg++13.3.0Success42,369
Dec 16, 2025 04:05HattonuriHattonuriCPPg++13.3.0Success42,659
Dec 16, 2025 04:04HattonuriHattonuriCPPg++13.3.0Success43,443
Dec 16, 2025 04:01HattonuriHattonuriCPPg++13.3.0Success45,707
Dec 16, 2025 03:45HattonuriHattonuriCPPg++13.3.0Success40,772
Dec 16, 2025 03:45HattonuriHattonuriCPPg++13.3.0Success42,709
Dec 16, 2025 03:44HattonuriHattonuriCPPg++13.3.0Success40,947
Dec 16, 2025 03:43HattonuriHattonuriCPPg++13.3.0Error
Dec 16, 2025 03:42HattonuriHattonuriCPPg++13.3.0Error
Dec 16, 2025 03:41HattonuriHattonuriCPPg++13.3.0Success40,164
Dec 16, 2025 03:38HattonuriHattonuriCPPg++13.3.0Success39,790+3.88 RP
Dec 16, 2025 03:36HattonuriHattonuriCPPg++13.3.0Success42,566
Dec 16, 2025 03:34HattonuriHattonuriCPPg++13.3.0Success48,114
Dec 16, 2025 03:29HattonuriHattonuriCPPg++13.3.0Success41,810
Dec 16, 2025 03:28HattonuriHattonuriCPPg++13.3.0Success42,414
Dec 16, 2025 03:27HattonuriHattonuriCPPg++13.3.0Success42,555
Dec 16, 2025 03:26HattonuriHattonuriCPPg++13.3.0Success40,414
Dec 16, 2025 03:23HattonuriHattonuriCPPg++13.3.0Success41,695
Dec 16, 2025 03:23HattonuriHattonuriCPPg++13.3.0Error
Dec 16, 2025 03:21HattonuriHattonuriCPPg++13.3.0Success41,955
Dec 16, 2025 03:21HattonuriHattonuriCPPg++13.3.0Success43,519
Dec 16, 2025 02:39HattonuriHattonuriCPPg++13.3.0Success45,257
Dec 16, 2025 01:56HattonuriHattonuriCPPg++13.3.0Success51,536
Dec 16, 2025 01:55HattonuriHattonuriCPPg++13.3.0Error
Dec 16, 2025 01:55HattonuriHattonuriCPPg++13.3.0Error
Dec 15, 2025 18:18HattonuriHattonuriCPPg++13.3.0Success42,590
Dec 15, 2025 18:18HattonuriHattonuriCPPg++13.3.0Success45,662
Dec 15, 2025 18:17HattonuriHattonuriCPPg++13.3.0Error
Dec 15, 2025 18:17HattonuriHattonuriCPPg++13.3.0Success43,017
Dec 15, 2025 18:13HattonuriHattonuriCPPg++13.3.0Success45,810
Dec 15, 2025 18:09HattonuriHattonuriCPPg++13.3.0Success44,752
Dec 15, 2025 18:06HattonuriHattonuriCPPg++13.3.0Success43,203
Dec 15, 2025 18:04HattonuriHattonuriCPPg++13.3.0Success46,090
Dec 15, 2025 18:02HattonuriHattonuriCPPg++13.3.0Success44,657
Dec 15, 2025 18:00HattonuriHattonuriCPPg++13.3.0Success42,172
Dec 15, 2025 18:00HattonuriHattonuriCPPg++13.3.0Error
Dec 15, 2025 17:57HattonuriHattonuriCPPg++13.3.0Error
Dec 15, 2025 17:56HattonuriHattonuriCPPg++13.3.0Error
Dec 15, 2025 17:55HattonuriHattonuriCPPg++13.3.0Error
Dec 15, 2025 17:53HattonuriHattonuriCPPg++13.3.0Error
Dec 15, 2025 17:52HattonuriHattonuriCPPg++13.3.0Error
Dec 15, 2025 17:51HattonuriHattonuriCPPg++13.3.0Error
Dec 15, 2025 17:48HattonuriHattonuriCPPg++13.3.0Error
Dec 15, 2025 17:48HattonuriHattonuriCPPg++13.3.0Error
Dec 15, 2025 17:43HattonuriHattonuriCPPg++13.3.0Error
Dec 15, 2025 17:40HattonuriHattonuriCPPg++13.3.0Error
Dec 15, 2025 17:37HattonuriHattonuriCPPg++13.3.0Error
Dec 15, 2025 17:37HattonuriHattonuriCPPg++13.3.0Error
Dec 15, 2025 17:35HattonuriHattonuriCPPg++13.3.0Error