E. Дерево делителей
ограничение по времени на тест
0.5 секунд
ограничение по памяти на тест
256 мегабайт
ввод
stdin
вывод
stdout

Дерево делителей — это корневое дерево, для которого выполняются следующие условия:

  • В каждой из вершин дерева записано целое положительное число.
  • В листьях дерева записаны простые числа.
  • Для любой внутренней вершины произведение чисел, записанных в ее сыновьях, равно числу, записанному в этой вершине.

У Манао есть n различных чисел a1, a2, ..., an. Он пытается построить такое дерево делителей, в вершинах которого каждое из ai будет встречаться хотя бы по одному разу. Манао любит компактность, но деревья у него получаются уж слишком большие. Помогите Манао определить минимальное возможное количество вершин в искомом дереве делителей.

Входные данные

Первая строка содержит единственное целое число n (1 ≤ n ≤ 8). Во второй строке через пробел записаны n различных целых чисел ai (2 ≤ ai ≤ 1012).

Выходные данные

Выведите единственное число — минимальное количество вершин в дереве делителей, содержащем каждое из чисел ai.

Примеры
Входные данные
2
6 10
Выходные данные
7
Входные данные
4
6 72 8 4
Выходные данные
12
Входные данные
1
7
Выходные данные
1
Примечание

Пример 1. Самое маленькое дерево делителей выглядит так:

Пример 2. В этом случае можно построить следующее дерево делителей:

Пример 3. Дерево может состоять из единственной вершины.