#arc101d. [arc101_d]Robots and Exits

[arc101_d]Robots and Exits

問題文

数直線上に NN 体のロボットと MM 個の出口があります。 これらの N+MN + M 個の座標はすべて整数であり、すべて相異なります。 各 ii (1leqileqN1 \\leq i \\leq N) について、左から ii 番目のロボットの座標は xix_i です。 また、各 jj (1leqjleqM1 \\leq j \\leq M) について、左から jj 番目の出口の座標は yjy_j です。

すぬけ君は、次の 22 種類の操作を好きな順序で繰り返し行い、ロボットを一斉に動かすことができます。

  • 数直線上のすべてのロボットの座標を \-1\-1 する。
  • 数直線上のすべてのロボットの座標を +1+1 する。

各ロボットは、いずれかの出口と重なった瞬間、その出口を通って数直線上から消えます。 すぬけ君は、すべてのロボットが消えるまで操作を行い続けます。

すべてのロボットが消えた後、各ロボットがどの出口を通ったかという組合せは何通りありうるでしょうか? 109+710^9 + 7 で割った余りを求めてください。 ただし、22 通りの組合せが異なるとは、あるロボットが存在し、そのロボットの通った出口が異なることを言います。

制約

  • 1leqN,Mleq1051 \\leq N, M \\leq 10^5
  • 1leqx1<x2<...<xNleq1091 \\leq x_1 < x_2 < ... < x_N \\leq 10^9
  • 1leqy1<y2<...<yMleq1091 \\leq y_1 < y_2 < ... < y_M \\leq 10^9
  • 与えられる座標はすべて整数である。
  • 与えられる座標はすべて相異なる。

入力

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

NN MM x1x_1 x2x_2 ...... xNx_N y1y_1 y2y_2 ...... yMy_M

出力

すべてのロボットが消えた後、各ロボットがどの出口を通ったかという組合せは何通りありうるか? 109+710^9 + 7 で割った余りを出力せよ。


入力例 1

2 2
2 3
1 4

出力例 1

3

左から ii 番目のロボットをロボット ii と呼び、左から jj 番目の出口を出口 jj と呼びます。 ((ロボット 11 が通った出口,, ロボット 22 が通った出口)) の組合せとしてありうるものは、次の 33 通りです。

  • ((出口 11,, 出口 11))
  • ((出口 11,, 出口 22))
  • ((出口 22,, 出口 22))

入力例 2

3 4
2 5 10
1 3 7 13

出力例 2

8

各ロボットごと独立に通る出口を決められるので、組合せは 23=82^3 = 8 通りです。


入力例 3

4 1
1 2 4 5
3

出力例 3

1

どのロボットも出口 11 を通ります。


入力例 4

4 5
2 5 7 11
1 3 6 9 13

出力例 4

6

入力例 5

10 10
4 13 15 18 19 20 21 22 25 27
1 5 11 12 14 16 23 26 29 30

出力例 5

22