配点 : 500 点
問題文
長さ N の数列 A=(A1,…,AN),B=(B1,…,BN) が与えられます。{1,2,…,N} の空でない部分集合 S であって、以下の条件を満たすものの個数を数えてください。
- maxi∈SAi≥∑i∈SBi
なお、答えは非常に大きくなることがあるため、998244353 で割ったあまりを出力してください。
制約
- 1≤N≤5000
- 1≤Ai,Bi≤5000
- 入力は全て整数
入力
入力は以下の形式で標準入力から与えられる。
N
A1 A2 … AN
B1 B2 … BN
出力
問題文中の条件を満たす S の個数を 998244353 で割ったあまりを出力せよ。
2
3 1
1 2
2
{1,2,…,N} の空でない部分集合としてあり得るものは、{1}, {2}, {1,2} の 3 通りです。
- S={1} のとき maxi∈SAi=3, ∑i∈SBi=1
- S={2} のとき maxi∈SAi=1, ∑i∈SBi=2
- S={1,2} のとき maxi∈SAi=3, ∑i∈SBi=3
であるため、問題文中の条件、即ち maxi∈SAi≥∑i∈SBi を満たす S は {1} と {1,2} の 2 通りです。
2
1 1
2 2
0
条件を満たす S が存在しない場合もあります。
20
1937 3980 2689 1208 3640 1979 581 2271 4229 3948 3708 1522 4161 4661 3797 96 3388 3395 2920 2247
4485 2580 174 1156 3770 3396 3558 3500 3494 479 269 3383 1230 1711 3545 3919 134 475 3796 1017
476