#include #define FOR(i,a,b) for(int i = (a); i < (b); ++i) #define REP(i,n) FOR(i,0,n) #define SZ(n) (int)(n).size() using namespace std; typedef long long ll; typedef vector VI; int main() { int n; cin >> n; VI a(n), b(n); REP(i, n) cin >> a[i]; REP(i, n) cin >> b[i]; int ans = 0; int x[101] = { 0 }; REP(i, n) { if (b[i] == 0) ans += a[i]; else x[b[i]] += a[i]; } sort(x, x + 101); if(ans >= x[100]) cout << "YES" << endl; else cout << "NO" << endl; return 0; }