}```cpp
#include <bits/stdc++.h>
using namespace std;
struct st{
int w,t;
};
st a[1000];
bool vis[555];
bool cmp(st A,st B)
{
return A.w>B.w;
}
int main(){
int n;
cin>>n;
for(int i=1;i<=n;i++)
cin>>a[i].t;
for(int i=1;i<=n;i++)
cin>>a[i].w;
sort(a+1,a+1+n,cmp);
int ans=0;
for(int i=1;i<=n;i++)
{
for(int j=a[i].t;j>=1;j--)
{
if(vis[j]==0)
{
vis[j]=1;
ans+=a[i].w;
break;
}
}
}
cout<<ans<<'\n';
return 0;
}