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 18, 2025 08:19Wookyung JeongWookyung JeongCPPg++13.3.0Success131,279
Dec 18, 2025 07:57Wookyung JeongWookyung JeongCPPg++13.3.0Error
Dec 18, 2025 07:47Wookyung JeongWookyung JeongCPPg++13.3.0Success40,717
Dec 18, 2025 07:25Wookyung JeongWookyung JeongCPPg++13.3.0Success42,234
Dec 18, 2025 07:22Wookyung JeongWookyung JeongCPPg++13.3.0Success40,240
Dec 18, 2025 07:19Wookyung JeongWookyung JeongCPPg++13.3.0Success40,369
Dec 18, 2025 07:19Wookyung JeongWookyung JeongCPPg++13.3.0Success39,959
Dec 18, 2025 07:05Wookyung JeongWookyung JeongCPPg++13.3.0Success39,497+2.35 RP
Dec 18, 2025 06:46Wookyung JeongWookyung JeongCPPg++13.3.0Success39,867+21.75 RP
Dec 18, 2025 06:27Wookyung JeongWookyung JeongCPPg++13.3.0Success96,393
Dec 18, 2025 06:15Wookyung JeongWookyung JeongCPPg++13.3.0Success45,248
Dec 18, 2025 06:13Wookyung JeongWookyung JeongCPPg++13.3.0Success44,143
Dec 18, 2025 06:13Wookyung JeongWookyung JeongCPPg++13.3.0Success44,655
Dec 18, 2025 06:09Wookyung JeongWookyung JeongCPPg++13.3.0Success44,740
Dec 18, 2025 06:08Wookyung JeongWookyung JeongCPPg++13.3.0Success45,069
Dec 18, 2025 05:56Wookyung JeongWookyung JeongCPPg++13.3.0Success44,764
Dec 18, 2025 05:55Wookyung JeongWookyung JeongCPPg++13.3.0Error
Dec 18, 2025 05:44Wookyung JeongWookyung JeongCPPg++13.3.0Success47,488
Dec 18, 2025 05:12Wookyung JeongWookyung JeongCPPg++13.3.0Success43,652+10.97 RP
Dec 18, 2025 05:08Wookyung JeongWookyung JeongCPPg++13.3.0Success45,848+22.36 RP
Dec 18, 2025 05:06Wookyung JeongWookyung JeongCPPg++13.3.0Success51,086+1.73 RP
Dec 18, 2025 05:02Wookyung JeongWookyung JeongCPPg++13.3.0Success53,288
Dec 17, 2025 02:20HattonuriHattonuriCPPg++13.3.0Success39,016
Dec 17, 2025 02:16HattonuriHattonuriCPPclang++18.1.3Success39,983
Dec 17, 2025 02:16HattonuriHattonuriCPPg++13.3.0Success39,055
Dec 17, 2025 02:14HattonuriHattonuriCPPg++13.3.0Success40,183
Dec 17, 2025 02:13HattonuriHattonuriCPPg++13.3.0Success38,538
Dec 17, 2025 02:10HattonuriHattonuriCPPg++13.3.0Success38,928
Dec 17, 2025 02:07HattonuriHattonuriCPPg++13.3.0Success41,469
Dec 17, 2025 02:07HattonuriHattonuriCPPg++13.3.0Success37,760
Dec 17, 2025 02:04HattonuriHattonuriCPPg++13.3.0Success40,159
Dec 17, 2025 02:03HattonuriHattonuriCPPg++13.3.0Success38,957
Dec 17, 2025 02:02HattonuriHattonuriCPPg++13.3.0Success37,784
Dec 17, 2025 02:01HattonuriHattonuriCPPg++13.3.0Success39,159
Dec 17, 2025 02:00HattonuriHattonuriCPPg++13.3.0Success38,395
Dec 17, 2025 01:59HattonuriHattonuriCPPg++13.3.0Success40,710
Dec 17, 2025 01:58HattonuriHattonuriCPPg++13.3.0Error
Dec 17, 2025 01:56HattonuriHattonuriCPPg++13.3.0Error
Dec 17, 2025 01:55HattonuriHattonuriCPPg++13.3.0Success38,719
Dec 17, 2025 01:54HattonuriHattonuriCPPclang++18.1.3Success40,457
Dec 17, 2025 01:53HattonuriHattonuriCPPclang++18.1.3Error
Dec 17, 2025 01:51HattonuriHattonuriCPPg++13.3.0Success40,345
Dec 17, 2025 01:50HattonuriHattonuriCPPg++13.3.0Success37,881
Dec 17, 2025 01:49HattonuriHattonuriCPPg++13.3.0Error
Dec 17, 2025 01:47HattonuriHattonuriCPPg++13.3.0Success39,860
Dec 17, 2025 01:45HattonuriHattonuriCPPg++13.3.0Success38,453
Dec 17, 2025 01:42HattonuriHattonuriCPPg++13.3.0Success37,697+0.47 RP
Dec 17, 2025 01:42HattonuriHattonuriCPPg++13.3.0Error
Dec 17, 2025 01:41HattonuriHattonuriCPPg++13.3.0Error
Dec 17, 2025 01:38HattonuriHattonuriCPPg++13.3.0Success38,226
Dec 17, 2025 01:37HattonuriHattonuriCPPg++13.3.0Success38,872
Dec 17, 2025 01:37HattonuriHattonuriCPPg++13.3.0Error
Dec 17, 2025 01:33HattonuriHattonuriCPPg++13.3.0Error
Dec 17, 2025 01:32HattonuriHattonuriCPPg++13.3.0Error
Dec 17, 2025 01:32HattonuriHattonuriCPPg++13.3.0Error
Dec 17, 2025 01:29HattonuriHattonuriCPPg++13.3.0Error
Dec 17, 2025 01:28HattonuriHattonuriCPPg++13.3.0Error
Dec 17, 2025 01:25HattonuriHattonuriCPPg++13.3.0Success37,764+5.49 RP
Dec 17, 2025 01:15HattonuriHattonuriCPPg++13.3.0Success38,564+7.99 RP
Dec 17, 2025 00:59HattonuriHattonuriCPPg++13.3.0Success42,102
Dec 17, 2025 00:59HattonuriHattonuriCPPg++13.3.0Success40,428
Dec 17, 2025 00:58HattonuriHattonuriCPPg++13.3.0Success41,288
Dec 17, 2025 00:57HattonuriHattonuriCPPg++13.3.0Success42,484
Dec 17, 2025 00:57HattonuriHattonuriCPPg++13.3.0Success41,209
Dec 17, 2025 00:51HattonuriHattonuriCPPg++13.3.0Success44,962
Dec 17, 2025 00:50HattonuriHattonuriCPPg++13.3.0Success42,976
Dec 17, 2025 00:47HattonuriHattonuriCPPg++13.3.0Success43,774
Dec 17, 2025 00:40HattonuriHattonuriCPPg++13.3.0Success44,853
Dec 17, 2025 00:39HattonuriHattonuriCPPg++13.3.0Success43,721
Dec 17, 2025 00:32HattonuriHattonuriCPPg++13.3.0Success42,903
Dec 16, 2025 23:45HattonuriHattonuriCPPg++13.3.0Success42,341
Dec 16, 2025 23:37HattonuriHattonuriCPPg++13.3.0Success41,200
Dec 16, 2025 23:35HattonuriHattonuriCPPg++13.3.0Success42,221
Dec 16, 2025 23:33HattonuriHattonuriCPPg++13.3.0Success39,821
Dec 16, 2025 23:33HattonuriHattonuriCPPg++13.3.0Success42,910
Dec 16, 2025 23:32HattonuriHattonuriCPPg++13.3.0Success40,771
Dec 16, 2025 23:30HattonuriHattonuriCPPg++13.3.0Success41,884
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