atcoder#AGC043F. [AGC043F] Jewelry Box

[AGC043F] Jewelry Box

配点 : 21002100

問題文

11 から NN までの番号のついた NN 軒の宝石店があります.

宝石店 ii (1iN1 \leq i \leq N) では,KiK_i 種類の宝石が売られています. このうち,jj (1jKi1 \leq j \leq K_i) 種類目の宝石は,大きさが Si,jS_{i,j},値段が Pi,jP_{i,j} で,在庫が Ci,jC_{i,j} 個あります.

よい 宝石箱とは,以下の条件をすべて満たす宝石箱です.

  • 宝石箱の中には,各宝石店で買った宝石が 11 個ずつ入っている.
  • 次の MM 個の条件をすべて満たす.- ii (1iM1 \leq i \leq M) 番目の条件: ((宝石店 ViV_i で買った宝石の大きさ)()\leq (宝石店 UiU_i で買った宝石の大きさ)+Wi)+W_i
  • ii (1iM1 \leq i \leq M) 番目の条件: ((宝石店 ViV_i で買った宝石の大きさ)()\leq (宝石店 UiU_i で買った宝石の大きさ)+Wi)+W_i

次の QQ 個の質問に答えてください. ii (1iQ1 \leq i \leq Q) 番目の質問では,整数 AiA_i が与えられるので,AiA_i 個のよい宝石箱を準備するとき,買う宝石の値段の合計の最小値を求めてください. ただし,AiA_i 個のよい宝石箱が準備できない場合はその旨を答えてください.

制約

  • 1N301 \leq N \leq 30
  • 1Ki301 \leq K_i \leq 30
  • 1Si,j1091 \leq S_{i,j} \leq 10^9
  • 1Pi,j301 \leq P_{i,j} \leq 30
  • 1Ci,j10121 \leq C_{i,j} \leq 10^{12}
  • 0M500 \leq M \leq 50
  • 1Ui,ViN1 \leq U_i,V_i \leq N
  • UiViU_i \neq V_i
  • 0Wi1090 \leq W_i \leq 10^9
  • 1Q1051 \leq Q \leq 10^5
  • 1Ai3×10131 \leq A_i \leq 3 \times 10^{13}
  • 入力は全て整数である.

入力

入力は以下の形式で標準入力から与えられる。

NN

宝石店$\ 1$の情報

宝石店$\ 2$の情報

\vdots

宝石店$\ N$の情報

MM

U1U_1 V1V_1 W1W_1

U2U_2 V2V_2 W2W_2

\vdots

UMU_M VMV_M WMW_M

QQ

A1A_1

A2A_2

\vdots

AQA_Q

宝石店 ii (1iN1 \leq i \leq N) の情報は,以下の形式で与えられる.

KiK_i

Si,1S_{i,1} Pi,1P_{i,1} Ci,1C_{i,1}

Si,2S_{i,2} Pi,2P_{i,2} Ci,2C_{i,2}

\vdots

Si,KiS_{i,K_i} Pi,KiP_{i,K_i} Ci,KiC_{i,K_i}

出力

QQ 行出力せよ. そのうち ii 行目には,AiA_i 個のよい宝石箱を準備するときに買う宝石の値段の合計の最小値を出力せよ. ただし,AiA_i 個のよい宝石箱を準備することが不可能な場合は,1-1 を出力せよ.

3
2
1 10 1
3 1 1
3
1 10 1
2 1 1
3 10 1
2
1 1 1
3 10 1
2
1 2 0
2 3 0
3
1
2
3
3
42
-1

宝石店 ii で売られている jj 種類目の宝石を宝石 (i,j)(i,j) で表すことにします.

各クエリの答えは,以下のようになります.

  • A1=1A_1=1: 宝石 (1,2),(2,2),(3,1)(1,2),(2,2),(3,1) を使う宝石箱を準備すると,コストが 1+1+1=31+1+1=3 となり,最小.
  • A2=2A_2=2: 宝石 (1,1),(2,1),(3,1)(1,1),(2,1),(3,1) を使う宝石箱と,宝石 (1,2),(2,3),(3,2)(1,2),(2,3),(3,2) を使う宝石箱を準備すると, コストが (10+10+1)+(1+10+10)=42(10+10+1)+(1+10+10)=42 となり,最小.
  • A3=3A_3=3: 33 つの良い宝石箱を準備することはできない.
5
5
86849520 30 272477201869
968023357 28 539131386006
478355090 8 194500792721
298572419 6 894877901270
203794105 25 594579473837
5
730211794 22 225797976416
842538552 9 420531931830
871332982 26 81253086754
553846923 29 89734736118
731788040 13 241088716205
5
903534485 22 140045153776
187101906 8 145639722124
513502442 9 227445343895
499446330 6 719254728400
564106748 20 333423097859
5
332809289 8 640911722470
969492694 21 937931959818
207959501 11 217019915462
726936503 12 382527525674
887971218 17 552919286358
5
444983655 13 487875689585
855863581 6 625608576077
885012925 10 105520979776
980933856 1 711474069172
653022356 19 977887412815
10
1 2 231274893
2 3 829836076
3 4 745221482
4 5 935448462
5 1 819308546
3 5 815839350
5 3 513188748
3 1 968283437
2 3 202352515
4 3 292999238
10
510266667947
252899314976
510266667948
374155726828
628866122125
628866122123
1
628866122124
510266667949
30000000000000
26533866733244
13150764378752
26533866733296
19456097795056
-1
33175436167096
52
33175436167152
26533866733352
-1