#include <bits/stdc++.h>
#define rep(i,n) for(int i = 0; i < (int)(n); i++)

using namespace std;
using LL = long long;
using P = pair<int,int>;
using vv = vector<vector<int>>;
const int INF = (int)1e9;
const LL LINF = (LL)1e18;

vector<int> res(1000010);

int main(){
	int N;
	cin >> N;
	vector<int> A(N);
	rep(i,N) cin >> A[i];
	rep(i,N){
		for(int d = 1; d * d <= A[i]; d++){
			if(A[i] % d == 0){
				res[d]++;
				if(A[i] / d != d) res[A[i] / d]++;
			}
		}
	}
	vector<int> ans(N+1);
	rep(i,1000005) res[i] = N - res[i];
	rep(i,1000005) ans[res[i]] = i;
	rep(i,N) ans[i+1] = max(ans[i+1], ans[i]);
	rep(i,N) cout << ans[i] << endl;

	return 0;
}