#include<bits/stdc++.h>
using namespace std;
unsigned long long read(){
unsigned long long x=0,f=1;char ch=getchar();
while (!isdigit(ch)){if (ch=='-') f=-1;ch=getchar();}
while (isdigit(ch)){x=x*10+ch-48;ch=getchar();}
return x*f;
}
unsigned long long n,a[1000005],b[1000005],ctt;
unsigned long long ans=0,maxnum;
int main(){
n=read();
for(int i=1;i<=n;++i) a[i]=read();
for(int i=1;i<=n;++i) b[i]=read();
sort(a+1,a+1+n);
sort(b+1,b+1+n);
maxnum=a[n];
for(int i=n-1;i>=1;--i){
if(a[i]==a[i+1]){
ctt++;
}
}
for(int i=n-1;i>=1;--i){
if(a[i]==a[i+1]){
ans+=(maxnum-a[i]+1)*b[ctt];
ctt--;
maxnum++;
}
}
cout<<ans;
return 0;
}