配点: 400 点
問題文
AtCoder 洋菓子店は数字の形をしたキャンドルがついたケーキを販売しています。
ここには 1,2,3 の形をしたキャンドルがついたケーキがそれぞれ X 種類、Y 種類、Z 種類あります。
それぞれのケーキには「美味しさ」という整数の値が以下のように割り当てられています。
- 1 の形のキャンドルがついたケーキの美味しさはそれぞれ A1,A2,...,AX
- 2 の形のキャンドルがついたケーキの美味しさはそれぞれ B1,B2,...,BY
- 3 の形のキャンドルがついたケーキの美味しさはそれぞれ C1,C2,...,CZ
高橋君は ABC 123 を記念するために、1,2,3 の形のキャンドルがついたケーキを 1 つずつ買うことにしました。
そのようにケーキを買う方法は X×Y×Z 通りあります。
これらの選び方を 3 つのケーキの美味しさの合計が大きい順に並べたとき、1,2,...,K 番目の選び方でのケーキの美味しさの合計をそれぞれ出力してください。
制約
- 1≤X≤1 000
- 1≤Y≤1 000
- 1≤Z≤1 000
- 1≤K≤min(3 000,X×Y×Z)
- 1≤Ai≤10 000 000 000
- 1≤Bi≤10 000 000 000
- 1≤Ci≤10 000 000 000
- 入力中の値はすべて整数である。
入力
入力は以下の形式で標準入力から与えられる。
X Y Z K
A1 A2 A3 ... AX
B1 B2 B3 ... BY
C1 C2 C3 ... CZ
出力
i 行目に、問題文中の i 番目の値を出力せよ。
2 2 2 8
4 6
1 5
3 8
19
17
15
14
13
12
10
8
3 つのケーキの選び方は 2×2×2=8 通りあり、それらをケーキの美味しさの合計が大きい順に並べると以下の通りです。
- (A2,B2,C2): 6+5+8=19
- (A1,B2,C2): 4+5+8=17
- (A2,B1,C2): 6+1+8=15
- (A2,B2,C1): 6+5+3=14
- (A1,B1,C2): 4+1+8=13
- (A1,B2,C1): 4+5+3=12
- (A2,B1,C1): 6+1+3=10
- (A1,B1,C1): 4+1+3=8
3 3 3 5
1 10 100
2 20 200
1 10 100
400
310
310
301
301
美味しさの合計が同じになる組み合わせが複数ある可能性もあります。例えば、このテストケースで (A1,B3,C3) を選ぶときと (A3,B3,C1) を選ぶときはともに、美味しさの合計が 301 となります。
しかし、これらは異なる選び方であるため、出力には 301 が 2 回出現します。
10 10 10 20
7467038376 5724769290 292794712 2843504496 3381970101 8402252870 249131806 6310293640 6690322794 6082257488
1873977926 2576529623 1144842195 1379118507 6003234687 4925540914 3902539811 3326692703 484657758 2877436338
4975681328 8974383988 2882263257 7690203955 514305523 6679823484 4263279310 585966808 3752282379 620585736
23379871545
22444657051
22302177772
22095691512
21667941469
21366963278
21287912315
21279176669
21160477018
21085311041
21059876163
21017997739
20703329561
20702387965
20590247696
20383761436
20343962175
20254073196
20210218542
20150096547
入力・出力は 32 ビット整数に収まらない可能性があることに注意してください。