#include #define fi first #define se second #define rep(i,s,n) for (int i = (s); i < (n); ++i) #define rrep(i,n,g) for (int i = (n)-1; i >= (g); --i) #define all(a) a.begin(),a.end() #define rall(a) a.rbegin(),a.rend() #define len(x) (int)(x).size() #define dup(x,y) (((x)+(y)-1)/(y)) #define pb push_back #define eb emplace_back #define Field(T) vector> #define pq(T) priority_queue, greater> using namespace std; using ll = long long; using ull = unsigned long long; using P = pair; templatebool chmax(T&a,T b){if(abool chmin(T&a,T b){if(b> n >> t; vector a(n-1); rep(i,0,n-1) cin >> a[i]; int k; cin >> k; vector x(n, 0); rep(i,0,k) { int xi; cin >> xi; x[xi-1] = 1; } function f = [&](int c) { int v = t; int cnt = 0; rep(i,0,n-1) { v -= a[i]; if (v <= 0) return false; if (x[i+1] && cnt < c) { v += 10; ++cnt; } } return true; }; // rep(i,0,k+1) { // cout << f(i) << " "; // } // cout << endl; if (!f(k)) { cout << -1 << endl; return 0; } int ng = -1, ok = k; while(ok-ng > 1) { int mid = (ok+ng)/2; if (f(mid)) ok = mid; else ng = mid; } cout << ok << endl; return 0; }