import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int n = sc.nextInt(); int[] a = new int[n]; int[] b = new int[n]; int max = -1001001001; int[] point = new int[n + 1]; for(int i = 0 ; i < n ; i++) { a[i] = sc.nextInt(); } for(int i = 0 ; i < n ; i++) { b[i] = sc.nextInt(); } for(int i = 0 ; i < n ; i++) { if(b[i] != 0) { point[b[i]] += a[i]; } } for(int i = 1 ; i <= n ; i++) { max = Math.max(max, point[i]); } int ret = 0; for(int i = 0 ; i < n ; i++) { if(b[i] == 0) { ret += a[i]; } } if(ret >= max) { System.out.println("YES"); } else { System.out.println("NO"); } } }