n=int(input()) d=map(int,input().split()) w=map(int,input().split()) uf=list(range(n)) rv=[False]*n def find(n): if n==uf[n]: return n else: uf[n]=find(uf[n]) return uf[n] def union(a,b): uf[find(a)]=find(b) for i,di in enumerate(d): union((i+di)%n,(i-di)%n) if (i+di)%n==(i-di)%n: rv[(i+di)%n]=True for i,b in enumerate(rv): if b: rv[find(i)]=True for i in set(uf): cnt=0 for n,wi in enumerate(w): if uf[n]==i and wi==0: cnt+=1 if not rv[i] and cnt%2!=0: print("No") break else: print("Yes")