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
Nov 10, 2024 11:31E SequeiraE SequeiraGOgo1.22.5Error
Nov 10, 2024 11:25E SequeiraE SequeiraGOgo1.22.5Success129,645
Nov 10, 2024 09:34E SequeiraE SequeiraGOgo1.22.5Success128,216
Nov 10, 2024 09:33E SequeiraE SequeiraGOgo1.22.5Success127,710
Nov 10, 2024 09:32E SequeiraE SequeiraGOgo1.22.5Error
Nov 10, 2024 09:31E SequeiraE SequeiraGOgo1.22.5Success127,972
Nov 10, 2024 09:29E SequeiraE SequeiraGOgo1.22.5Success127,355
Nov 10, 2024 09:28E SequeiraE SequeiraGOgo1.22.5Success128,128
Nov 10, 2024 09:24E SequeiraE SequeiraGOgo1.22.5Success132,110
Nov 10, 2024 09:23E SequeiraE SequeiraGOgo1.22.5Success132,038
Nov 10, 2024 09:21E SequeiraE SequeiraGOgo1.22.5Success131,278
Nov 10, 2024 09:19E SequeiraE SequeiraGOgo1.22.5Error
Nov 10, 2024 09:18E SequeiraE SequeiraGOgo1.22.5Error
Nov 10, 2024 09:16E SequeiraE SequeiraGOgo1.22.5Success166,760
Nov 10, 2024 09:15E SequeiraE SequeiraGOgo1.22.5Success166,143
Nov 10, 2024 09:14E SequeiraE SequeiraGOgo1.22.5Success221,638
Nov 10, 2024 09:14E SequeiraE SequeiraGOgo1.22.5Success220,369
Nov 10, 2024 09:12E SequeiraE SequeiraGOgo1.22.5Success164,788
Nov 10, 2024 09:11E SequeiraE SequeiraGOgo1.22.5Success165,264
Nov 10, 2024 09:10E SequeiraE SequeiraGOgo1.22.5Success165,853
Nov 10, 2024 09:06E SequeiraE SequeiraGOgo1.22.5Success173,905
Nov 10, 2024 09:04E SequeiraE SequeiraGOgo1.22.5Success210,410
Nov 10, 2024 09:02E SequeiraE SequeiraCPPclang++18.1.3Error
Nov 10, 2024 09:00E SequeiraE SequeiraCPPclang++18.1.3Error
Nov 10, 2024 08:51E SequeiraE SequeiraCPPclang++18.1.3Error
Nov 10, 2024 08:50E SequeiraE SequeiraCPPclang++18.1.3Error
Nov 10, 2024 08:42E SequeiraE SequeiraCPPclang++18.1.3Success77,847
Nov 10, 2024 08:41E SequeiraE SequeiraCPPclang++18.1.3Error
Nov 10, 2024 08:39E SequeiraE SequeiraCPPclang++18.1.3Error
Nov 9, 2024 22:57E SequeiraE SequeiraCPPclang++18.1.3Success77,629
Nov 9, 2024 22:57E SequeiraE SequeiraCPPg++13.2.0Success91,316
Nov 9, 2024 22:57E SequeiraE SequeiraCPPclang++10.0.0Success77,797
Nov 9, 2024 22:56E SequeiraE SequeiraCPPclang++10.0.0Success78,369
Nov 9, 2024 22:56E SequeiraE SequeiraCPPclang++10.0.0Success79,060
Nov 9, 2024 22:55E SequeiraE SequeiraCPPclang++10.0.0Success78,790
Nov 9, 2024 22:55E SequeiraE SequeiraCPPclang++10.0.0Error
Nov 9, 2024 22:54E SequeiraE SequeiraCPPclang++10.0.0Error
Nov 7, 2024 11:42NoSIMD_C#NoSIMD_C#CPPclang++18.1.3Success2,409,014+4.15 RP
Nov 6, 2024 07:01Mikhail ShirokovMikhail ShirokovCPPg++13.2.0Success1,744,552
Oct 27, 2024 22:13Paulius GasparaviciusPaulius GasparaviciusCPPclang++18.1.3Success2,465,559
Oct 27, 2024 22:12Paulius GasparaviciusPaulius GasparaviciusCPPclang++18.1.3Error
Oct 27, 2024 22:09Paulius GasparaviciusPaulius GasparaviciusCPPclang++18.1.3Success2,311,150+4.33 RP
Oct 23, 2024 00:06Mikhail ShirokovMikhail ShirokovCPPg++13.2.0Success1,739,628+0.49 RP
Oct 23, 2024 00:01Mikhail ShirokovMikhail ShirokovCPPclang++18.1.3Success1,964,184
Oct 23, 2024 00:00Mikhail ShirokovMikhail ShirokovCPPg++13.2.0Success1,901,581+0.07 RP
Oct 22, 2024 23:59Mikhail ShirokovMikhail ShirokovCPPg++13.2.0Success1,937,395
Oct 20, 2024 00:09Angello Gianni HernandezAngello Gianni HernandezCPPclang++18.1.3Success2,328,516+4.29 RP
Oct 19, 2024 12:03@drytecc@dryteccCPPclang++18.1.3Error
Oct 19, 2024 09:10@drytecc@dryteccCPPclang++18.1.3Success17,079
Oct 19, 2024 09:10@drytecc@dryteccCPPclang++18.1.3Error
Oct 19, 2024 09:10@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 21:36@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 21:36@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 21:36@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 21:36@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 21:36@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 21:34Joad NacerJoad NacerCPPclang++18.1.3Success2,336,031
Oct 18, 2024 21:29Joad NacerJoad NacerCPPclang++18.1.3Success2,376,197
Oct 18, 2024 21:28Joad NacerJoad NacerCPPclang++18.1.3Success2,309,400+0.03 RP
Oct 18, 2024 21:25Joad NacerJoad NacerCPPclang++18.1.3Success2,388,036
Oct 18, 2024 21:20Joad NacerJoad NacerCPPg++9.4.0Success2,323,821+4.30 RP
Oct 18, 2024 21:06@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 21:05@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 21:05@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 21:05@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 21:05@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 20:38@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 20:38@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 20:38@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 20:38@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 20:38@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 19:48@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 19:47@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 19:47@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 19:47@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 19:47@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 19:46@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 19:46@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 19:46@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 19:46@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 19:46@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 13:13matsuoka-601matsuoka-601CPPg++13.2.0Success38,240
Oct 18, 2024 13:04matsuoka-601matsuoka-601CPPclang++18.1.3Success38,819
Oct 18, 2024 11:28@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 10:02@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 10:02@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 09:57@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 09:57@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 09:56@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 09:52@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 09:52@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 09:52@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 09:51@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 09:51@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 08:59@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 08:58@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 08:57@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 08:57@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 08:56@drytecc@dryteccCPPclang++18.1.3Error
Oct 18, 2024 08:55@drytecc@dryteccCPPclang++18.1.3Error