Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only ICPC mode for virtual contests.
If you've seen these problems, a virtual contest is not for you - solve these problems in the archive.
If you just want to solve some problem from a contest, a virtual contest is not for you - solve this problem in the archive.
Never use someone else's code, read the tutorials or communicate with other person during a virtual contest.

No tag edit access

D. Lesson Timetable

time limit per test

1 secondmemory limit per test

256 megabytesinput

standard inputoutput

standard outputWhen Petya has free from computer games time, he attends university classes. Every day the lessons on Petya’s faculty consist of two double classes. The floor where the lessons take place is a long corridor with *M* classrooms numbered from 1 to *M*, situated along it.

All the students of Petya’s year are divided into *N* groups. Petya has noticed recently that these groups’ timetable has the following peculiarity: the number of the classroom where the first lesson of a group takes place does not exceed the number of the classroom where the second lesson of this group takes place.

Once Petya decided to count the number of ways in which one can make a lesson timetable for all these groups. The timetable is a set of 2*N* numbers: for each group the number of the rooms where the first and the second lessons take place. Unfortunately, he quickly lost the track of his calculations and decided to count only the timetables that satisfy the following conditions:

1) On the first lesson in classroom *i* exactly *X*_{i} groups must be present.

2) In classroom *i* no more than *Y*_{i} groups may be placed.

Help Petya count the number of timetables satisfying all those conditionsю As there can be a lot of such timetables, output modulo 10^{9} + 7.

Input

The first line contains one integer *M* (1 ≤ *M* ≤ 100) — the number of classrooms.

The second line contains *M* space-separated integers — *X*_{i} (0 ≤ *X*_{i} ≤ 100) the amount of groups present in classroom *i* during the first lesson.

The third line contains *M* space-separated integers — *Y*_{i} (0 ≤ *Y*_{i} ≤ 100) the maximal amount of groups that can be present in classroom *i* at the same time.

It is guaranteed that all the *X*_{i} ≤ *Y*_{i}, and that the sum of all the *X*_{i} is positive and does not exceed 1000.

Output

In the single line output the answer to the problem modulo 10^{9} + 7.

Examples

Input

3

1 1 1

1 2 3

Output

36

Input

3

1 1 1

1 1 1

Output

6

Note

In the second sample test the first and the second lessons of each group must take place in the same classroom, that’s why the timetables will only be different in the rearrangement of the classrooms’ numbers for each group, e.g. 3! = 6.

Codeforces (c) Copyright 2010-2019 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Sep/23/2019 15:24:03 (f2).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|