#include<cstdio>
#include<algorithm>
using namespace std;
#define N 100010
int n,cnt,a[N],b[N],c[N*30];
int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++) scanf("%d",a+i);
for(int i=1;i<=n;i++) scanf("%d",b+i);
sort(a+1,a+n+1);
sort(b+1,b+n+1);
for(int i=1;i<=n;i++){
for(int j=1;i*j<=n;j++){
c[++cnt]=a[i]+b[j];
}
}
sort(c+1,c+cnt+1);
for(int i=1;i<=n;i++) printf("%d ",c[i]);
return 0;
}
#include<cstdio>
#include<algorithm>
#include<queue>
#include<vector>
using namespace std;
#define N 100010
int n,cnt,a[N],b[N];
priority_queue<int,vector<int>,greater<int> >que;
int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++) scanf("%d",a+i);
for(int i=1;i<=n;i++) scanf("%d",b+i);
sort(a+1,a+n+1);
sort(b+1,b+n+1);
for(int i=1;i<=n;i++){
for(int j=1;i*j<=n;j++){
que.push(a[i]+b[j]);
}
}
for(int i=1;i<=n;i++){
printf("%d ",que.top());que.pop();
}
return 0;
}