#include <algorithm>
#include <cstdio>
#include <cstring>
#include <map>
using namespace std;
map<int, int> m;
map<int, int>::iterator it;
int n, v[2001], po, cnt, x, a[2001][11], la, fa[30001], siz[30001], tot,
    las[2001], c[20001], mx;
bool b[2001], bo[2001], bb[30001];
int gcd(int a, int b) { return (!b) ? a : gcd(b, a % b); }
int ask(int x) { return fa[x] == x ? x : fa[x] = ask(fa[x]); }
int getmax(int a, int b) { return a > b ? a : b; }
void unite(int x, int y) {
  int p = ask(x), q = ask(y);
  if (p == q)
    return;
  fa[p] = q;
  siz[q] += siz[p];
}
int main() {
  scanf("%d", &n);
  for (int i = 1; i <= n; i++)
    scanf("%d", &v[i]);
  sort(v + 1, v + 1 + n);
  m.clear();
  cnt = 0;
  for (int i = 1; i <= n; i++) {
    x = v[i];
    for (int j = 2; j * j <= v[i]; j++)
      if (x % j == 0) {
        a[i][++a[i][0]] = j;
        while (x % j == 0)
          x /= j;
      }
    if (x != 1)
      a[i][++a[i][0]] = x;
    for (int j = 1; j <= a[i][0]; j++) {
      it = m.find(a[i][j]);
      if (it == m.end())
        m[a[i][j]] = ++cnt, a[i][j] = cnt;
      else
        a[i][j] = m[a[i][j]];
    }
  }
  memset(c, 0, sizeof(c));
  memset(las, 0, sizeof(las));
  la = (1e9);
  memset(b, 1, sizeof(b));
  for (int i = 1; i <= n; i++) {
    for (int j = 1; j <= cnt + 1; j++)
      fa[j] = j, siz[j] = 1;
    memset(bb, 0, sizeof(bb));
    for (int j = 1; j <= n; j++)
      if (b[j]) {
        for (int k = 1; k <= a[j][0]; k++)
          bb[a[j][k]] = 1;
        for (int k = 2; k <= a[j][0]; k++)
          unite(a[j][1], a[j][k]);
      }
    tot = 1;
    for (int j = 1; j <= cnt; j++)
      if (bb[j])
        tot++;
    for (int j = 1; j <= n; j++)
      if (b[j]) {
        mx = 0;
        for (int k = 1; k <= a[j][0]; k++)
          mx = getmax(mx, c[a[j][k]]);
        if (las[j] > mx)
          continue;
        if (a[j][0])
          unite(a[j][1], cnt + 1);
        if (siz[ask(cnt + 1)] == tot) {
          po = j;
          break;
        }
      }
    printf("%d ", v[po]);
    b[po] = 0;
    la = v[po];
    for (int j = po + 1; j <= n; j++)
      las[j] = i;
    for (int j = 1; j <= a[po][0]; j++)
      c[a[po][j]] = i;
  }
  printf("\n");
  return 0;
}