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 24, 2024 19:06Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 19:03Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 19:03Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 19:02Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 19:02Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 19:00Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 18:59Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 18:50Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 18:47Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 18:44Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 18:26Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 18:20Yuriy LyfenkoYuriy LyfenkoCPPg++13.2.0Error
Nov 24, 2024 18:19Yuriy LyfenkoYuriy LyfenkoCPPclang++18.1.3Error
Nov 24, 2024 17:40Yuriy LyfenkoYuriy LyfenkoCPPclang++18.1.3Error
Nov 24, 2024 17:40Yuriy LyfenkoYuriy LyfenkoCPPg++13.2.0Error
Nov 24, 2024 17:39Yuriy LyfenkoYuriy LyfenkoCPPg++13.2.0Error
Nov 24, 2024 17:38E SequeiraE SequeiraGOgo1.23.3Success126,974
Nov 24, 2024 17:37E SequeiraE SequeiraGOgo1.23.3Success131,886
Nov 24, 2024 17:36E SequeiraE SequeiraGOgo1.23.3Error
Nov 24, 2024 17:34E SequeiraE SequeiraGOgo1.23.3Success906,479
Nov 24, 2024 17:31E SequeiraE SequeiraGOgo1.23.3Success280,041
Nov 24, 2024 17:29E SequeiraE SequeiraGOgo1.23.3Error
Nov 24, 2024 17:25NoSIMD_C#NoSIMD_C#CSHARP9.0.0-rc.2Success4,185,586
Nov 24, 2024 17:25E SequeiraE SequeiraGOgo1.23.3Success183,962
Nov 24, 2024 17:24NoSIMD_C#NoSIMD_C#CSHARP9.0.0-rc.2Success4,206,605
Nov 24, 2024 17:23Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 17:22E SequeiraE SequeiraGOgo1.23.3Success126,878
Nov 24, 2024 17:22Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 17:21E SequeiraE SequeiraGOgo1.23.3Error
Nov 24, 2024 17:20NoSIMD_C#NoSIMD_C#CSHARP9.0.0-rc.2Error
Nov 24, 2024 17:20E SequeiraE SequeiraGOgo1.23.3Error
Nov 24, 2024 17:18E SequeiraE SequeiraGOgo1.23.3Success1,488,574
Nov 24, 2024 17:17NoSIMD_C#NoSIMD_C#CSHARP9.0.0-rc.2Success4,195,993
Nov 24, 2024 17:16NoSIMD_C#NoSIMD_C#CSHARP9.0.0-rc.2Error
Nov 24, 2024 17:15E SequeiraE SequeiraGOgo1.23.3Error
Nov 24, 2024 17:14NoSIMD_C#NoSIMD_C#CSHARP9.0.0-rc.2Success4,205,707
Nov 24, 2024 17:12NoSIMD_C#NoSIMD_C#CSHARP9.0.0-rc.2Error
Nov 24, 2024 17:11E SequeiraE SequeiraGOgo1.23.3Error
Nov 24, 2024 17:08E SequeiraE SequeiraGOgo1.23.3Error
Nov 24, 2024 17:07E SequeiraE SequeiraGOgo1.23.3Error
Nov 24, 2024 17:05E SequeiraE SequeiraGOgo1.23.3Error
Nov 24, 2024 17:03E SequeiraE SequeiraGOgo1.23.3Error
Nov 24, 2024 16:12NoSIMD_C#NoSIMD_C#CSHARP9.0.0-rc.2Error
Nov 24, 2024 16:08NoSIMD_C#NoSIMD_C#CSHARP9.0.0-rc.2Error
Nov 24, 2024 16:04NoSIMD_C#NoSIMD_C#CSHARP9.0.0-rc.2Error
Nov 24, 2024 15:58NoSIMD_C#NoSIMD_C#CSHARP9.0.0-rc.2Error
Nov 24, 2024 15:56NoSIMD_C#NoSIMD_C#CSHARP9.0.0-rc.2Error
Nov 24, 2024 15:52NoSIMD_C#NoSIMD_C#CSHARP9.0.0-rc.2Error
Nov 24, 2024 15:48NoSIMD_C#NoSIMD_C#CSHARP9.0.0-rc.2Error
Nov 24, 2024 15:34NoSIMD_C#NoSIMD_C#CSHARP9.0.0-rc.2Error
Nov 24, 2024 13:20NoSIMD_C#NoSIMD_C#GOgo1.23.3Success1,382,617+3.08 RP
Nov 24, 2024 05:57Yuriy LyfenkoYuriy LyfenkoCPPg++13.2.0Error
Nov 24, 2024 05:54Yuriy LyfenkoYuriy LyfenkoCPPg++13.2.0Error
Nov 24, 2024 05:53Yuriy LyfenkoYuriy LyfenkoCPPg++13.2.0Error
Nov 24, 2024 05:52Yuriy LyfenkoYuriy LyfenkoCPPg++13.2.0Error
Nov 24, 2024 05:14Yuriy LyfenkoYuriy LyfenkoCPPg++13.2.0Error
Nov 23, 2024 22:28E SequeiraE SequeiraGOgo1.23.3Success127,084
Nov 23, 2024 22:27E SequeiraE SequeiraGOgo1.23.3Success126,760
Nov 23, 2024 22:25E SequeiraE SequeiraGOgo1.23.3Success127,710
Nov 23, 2024 22:24E SequeiraE SequeiraGOgo1.23.3Success127,345
Nov 23, 2024 22:23E SequeiraE SequeiraGOgo1.23.3Success127,150
Nov 23, 2024 22:21E SequeiraE SequeiraRUSTrust-1.82.0Success106,710
Nov 23, 2024 22:09E SequeiraE SequeiraCPPclang++18.1.3Success74,862
Nov 23, 2024 22:06E SequeiraE SequeiraCPPclang++18.1.3Success73,817+0.55 RP
Nov 23, 2024 22:01E SequeiraE SequeiraCPPclang++18.1.3Success74,274
Nov 23, 2024 22:00E SequeiraE SequeiraCPPclang++18.1.3Success75,112
Nov 23, 2024 22:00E SequeiraE SequeiraCPPclang++18.1.3Success74,329
Nov 23, 2024 21:59E SequeiraE SequeiraCPPclang++18.1.3Success74,712
Nov 23, 2024 21:59E SequeiraE SequeiraCPPclang++18.1.3Success74,347
Nov 23, 2024 21:50E SequeiraE SequeiraCPPclang++18.1.3Success215,257
Nov 23, 2024 21:48E SequeiraE SequeiraCPPclang++18.1.3Error
Nov 23, 2024 21:47E SequeiraE SequeiraCPPclang++18.1.3Error
Nov 23, 2024 21:46E SequeiraE SequeiraCPPclang++18.1.3Error
Nov 23, 2024 21:43E SequeiraE SequeiraCPPclang++18.1.3Success76,252
Nov 23, 2024 21:41E SequeiraE SequeiraCPPclang++18.1.3Error
Nov 23, 2024 21:40E SequeiraE SequeiraCPPclang++18.1.3Success74,941
Nov 23, 2024 21:38E SequeiraE SequeiraCPPclang++18.1.3Error
Nov 23, 2024 21:34E SequeiraE SequeiraCPPclang++18.1.3Success75,678
Nov 23, 2024 21:30E SequeiraE SequeiraCPPclang++18.1.3Error
Nov 23, 2024 21:30E SequeiraE SequeiraCPPclang++18.1.3Error
Nov 23, 2024 21:22E SequeiraE SequeiraCPPclang++18.1.3Success74,460
Nov 23, 2024 21:22E SequeiraE SequeiraCPPclang++18.1.3Success74,117+0.40 RP
Nov 23, 2024 21:17E SequeiraE SequeiraCPPclang++18.1.3Success118,728
Nov 23, 2024 21:16E SequeiraE SequeiraCPPclang++18.1.3Error
Nov 23, 2024 21:14E SequeiraE SequeiraCPPclang++18.1.3Error
Nov 23, 2024 21:09E SequeiraE SequeiraCPPclang++18.1.3Error
Nov 23, 2024 21:09E SequeiraE SequeiraCPPclang++18.1.3Success75,922
Nov 23, 2024 21:08E SequeiraE SequeiraCPPclang++18.1.3Error
Nov 23, 2024 21:03E SequeiraE SequeiraCPPclang++18.1.3Error
Nov 23, 2024 21:02E SequeiraE SequeiraCPPclang++18.1.3Success102,836
Nov 23, 2024 21:00E SequeiraE SequeiraCPPclang++18.1.3Error
Nov 23, 2024 20:58E SequeiraE SequeiraCPPclang++18.1.3Success121,767
Nov 23, 2024 20:57E SequeiraE SequeiraCPPclang++18.1.3Error
Nov 23, 2024 20:22E SequeiraE SequeiraCPPclang++18.1.3Success74,340+2.54 RP
Nov 23, 2024 20:18E SequeiraE SequeiraCPPclang++18.1.3Success76,509
Nov 23, 2024 20:18E SequeiraE SequeiraCPPclang++18.1.3Success75,862
Nov 23, 2024 20:16E SequeiraE SequeiraCPPclang++18.1.3Success76,007
Nov 23, 2024 20:15E SequeiraE SequeiraCPPclang++18.1.3Success86,002
Nov 23, 2024 20:14E SequeiraE SequeiraCPPclang++18.1.3Success76,221
Nov 23, 2024 20:13E SequeiraE SequeiraCPPclang++18.1.3Success77,053