# 首先根据输入顺序,将砝码用数字序列表示,例如2个1g和1个2g,就用 1 1 2的序列表示;
# set序列用来表示加入当前砝码之前能产生的重量种类;
# set初始化为{0};当第一个1g砝码放入时,则set中需要插入原先set中的所有元素+1g后的结果;即{0, 0+1};
# 当第二个1g加入时,则set会插入{0+1, 1+1},就变成了{0, 1, 2};
# 重复上述步骤加入所有砝码;则最后set的大小即为能产生的重量种类
import sys
while True:
    try:
        n = int(input())
        ms = list(map(int, input().split()))
        xs = list(map(int, input().split()))
        m_l = []
        for i in range(len(ms)):
            for x in range(xs[i]):
                m_l.append(ms[i])
        c_set = {0}
        for m in m_l:
            for c in set(c_set):
                c_set.add(m + c)
        print(len(c_set))
    except:
#         print(sys.exc_info())
        break