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 27, 2024 18:29Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 27, 2024 18:28Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 27, 2024 18:28Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 27, 2024 18:27Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 27, 2024 18:26Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 27, 2024 18:25Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 27, 2024 18:24Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 27, 2024 18:24Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 27, 2024 18:21Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 27, 2024 18:14Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 27, 2024 18:13Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 27, 2024 18:12Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 27, 2024 18:12Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 27, 2024 18:09Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 27, 2024 18:09Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 27, 2024 18:08Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 27, 2024 18:07Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 27, 2024 17:30Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 27, 2024 17:30Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 27, 2024 17:29Joad NacerJoad NacerCPPclang++18.1.3Error
Nov 25, 2024 11:23E SequeiraE SequeiraCPPclang++18.1.3Success74,043
Nov 25, 2024 10:24E SequeiraE SequeiraCPPclang++18.1.3Success74,028
Nov 25, 2024 10:19E SequeiraE SequeiraGOgo1.23.3Success138,357
Nov 25, 2024 10:17E SequeiraE SequeiraGOgo1.23.3Error
Nov 25, 2024 10:07E SequeiraE SequeiraGOgo1.23.3Success139,628
Nov 25, 2024 09:53E SequeiraE SequeiraGOgo1.23.3Success131,267
Nov 25, 2024 09:52E SequeiraE SequeiraGOgo1.23.3Success130,900
Nov 25, 2024 09:51E SequeiraE SequeiraGOgo1.23.3Success126,241
Nov 25, 2024 09:50E SequeiraE SequeiraGOgo1.23.3Success126,234
Nov 25, 2024 09:50E SequeiraE SequeiraGOgo1.23.3Success128,224
Nov 25, 2024 09:47E SequeiraE SequeiraGOgo1.23.3Success128,609
Nov 25, 2024 07:57NoSIMD_C#NoSIMD_C#CSHARP9.0.0-rc.2Error
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