#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
#define fi first
#define se second
#define pb push_back
#define fastIO ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
#define MOD 1000000007
int main()
{
fastIO;
int n,m;
cin>>n>>m;
vector<int> r(n),w(m+1);
for(int i=0; i<n; i++) cin>>r[i];
for(int i=1; i<=m; i++) cin>>w[i];
queue<int> ie;
stack<int> b;
vector<int> g(m+1);
int rez=0;
for(int i=n-1; i>=0; i--) b.push(i);
for(int i=0; i<m*2; i++){
int c; cin>>c;
if(c>0){
ie.push(c);
}else{
b.push(g[abs(c)]);
}
while(ie.size()>0 && b.size()>0){
rez+=r[b.top()]*w[ie.front()];
g[ie.front()]=b.top();
b.pop();
ie.pop();
}
}
cout<<rez;
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |