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 25, 2024 07:21NoSIMD_C#NoSIMD_C#CSHARP9.0.0-rc.2Error
Nov 25, 2024 07:08NoSIMD_C#NoSIMD_C#CSHARP9.0.0-rc.2Error
Nov 24, 2024 22:43Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 22:42Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 22:31Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 22:30Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 22:29Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 22:29Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 22:28Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 22:22Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 22:21Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 22:21Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 22:20Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 21:23Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 21:22Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 21:21Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 21:12Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 21:05Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 21:00Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:57Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:55Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:53Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:53Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:52Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:39Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:36Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:31Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:22Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:18Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:16Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:16Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:13Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:12Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:11Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:10Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:08Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:07Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:06Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:04Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:02Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 20:02Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 19:56Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 19:53Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 19:53Joad NacerJoad NacerCPPclang++18.1.3Success37,957
Nov 24, 2024 19:52Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 19:48Joad NacerJoad NacerCPPg++13.2.0Success38,107
Nov 24, 2024 19:46Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 19:40Yuriy LyfenkoYuriy LyfenkoCPPg++13.2.0Success41,195
Nov 24, 2024 19:39Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 19:39Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 19:38Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 24, 2024 19:38Yuriy LyfenkoYuriy LyfenkoCPPg++13.2.0Error
Nov 24, 2024 19:37Yuriy LyfenkoYuriy LyfenkoCPPg++13.2.0Error
Nov 24, 2024 19:37Joad NacerJoad NacerCPPclang++18.1.3Success37,783
Nov 24, 2024 19:20Yuriy LyfenkoYuriy LyfenkoCPPclang++18.1.3Success46,355
Nov 24, 2024 19:17Yuriy LyfenkoYuriy LyfenkoCPPg++13.2.0Error
Nov 24, 2024 19:16Yuriy LyfenkoYuriy LyfenkoCPPg++13.2.0Error
Nov 24, 2024 19:14Yuriy LyfenkoYuriy LyfenkoCPPg++13.2.0Error
Nov 24, 2024 19:13Yuriy LyfenkoYuriy LyfenkoCPPg++13.2.0Error
Nov 24, 2024 19:11Yuriy LyfenkoYuriy LyfenkoCPPg++13.2.0Success40,572
Nov 24, 2024 19:10Yuriy LyfenkoYuriy LyfenkoCPPg++13.2.0Success38,491
Nov 24, 2024 19:09Yuriy LyfenkoYuriy LyfenkoCPPg++13.2.0Success46,933
Nov 24, 2024 19:09Yuriy LyfenkoYuriy LyfenkoCPPg++13.2.0Error
Nov 24, 2024 19:08Yuriy LyfenkoYuriy LyfenkoCPPg++13.2.0Success48,176
Nov 24, 2024 19:08Yuriy LyfenkoYuriy LyfenkoCPPg++13.2.0Success60,688
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