import sys import math def lcm(a, b): if a == 0 or b == 0: return 0 if a < b: a, b = b, a # Ensure a >= b if a % b == 0: return a return a * b // math.gcd(a, b) n = int(sys.stdin.readline()) arr = list(map(int, sys.stdin.readline().split())) for i in range(n-1): x = arr[i] sub = arr[i+1:] sub.sort(key=lambda elem: (lcm(x, elem), elem)) arr[i+1:] = sub print(' '.join(map(str, arr)))