#include "bits/stdc++.h" using namespace std; //#define int long long #define REP(i,n) for(int i = 0;i < (int)(n);i++) #define RREP(i,n) for(int i = (int)n-1;i >= 0;i--) #define FOR(i,s,n) for(int i = s;i < (int)n;i++) #define RFOR(i,s,n) for(int i = (int)n-1;i >= s;i--) #define ALL(a) a.begin(),a.end() #define IN(a, x, b) (a<=x && xinline bool CHMAX(T&a,T b){if(ainline bool CHMIN(T&a,T b){if(a>b){a = b;return true;}return false;} constexpr long long INF = 1e9; #include"ext/pb_ds/assoc_container.hpp" #include"ext/pb_ds/tree_policy.hpp" using namespace __gnu_pbds; template using pbds = tree,rb_tree_tag,tree_order_statistics_node_update>; /* insert(logN) erase(logN) find_by_order(logN)//k番目の要素のイテレータを返す order_of_key(logN)//k以上で最初の数が何番目かを返す (K未満の個数が何個あるかが分かるらしい) gp_hash_tablem//高速なmap */ signed main(){ int N; cin >> N; vectora(N); REP(i,N)cin >> a[i]; gp_hash_tablemp; REP(i,N){ int ma = 0; for(int j = 1;j * j <= a[i];j++){ if(a[i] % j)continue; if(j