import sys import math def lcm(a, b): return a * b // math.gcd(a, b) def main(): input = sys.stdin.read().split() N = int(input[0]) a = list(map(int, input[1:N+1])) for i in range(N - 1): current = a[i] sublist = a[i+1:] keys = [(lcm(current, x), x) for x in sublist] sorted_keys = sorted(keys, key=lambda k: (k[0], k[1])) sorted_sublist = [x for _, x in sorted_keys] a[i+1:] = sorted_sublist print(' '.join(map(str, a))) if __name__ == '__main__': main()