НОД
НОД (наибольший общий делитель) набора чисел это наибольшее число, на которое делятся все числа данного набора.
Алгоритм вычисления НОД c вычитаниями (алгоритм Евклида): выбираются два ненулевых числа из исходного набора, и большее число заменяется разностью большего и меньшего. Эта операция повторяется, пока в наборе остаётся не менее двух ненулевых чисел.
Если все числа, кроме одного, стали равны 0, то алгоритм завершается, а оставшееся ненулевое число и есть НОД исходного набора.
Один шаг алгоритма: выбор двух ненулевых чисел из исходного набора и замена большего разностью. Существует много стратегий выбора на очередном шаге пары чисел. При этом количество шагов при разных стратегиях будет различным.
Требуется написать программу, определяющую минимальное количество шагов при вычислении НОД вычитаниями для данного набора чисел.
Входные данные
Содержит несколько (до 1000) тестов. Каждый тест записан в отдельной строке и начинается с количества чисел в наборе n (n ≤ 4). Далее в строке идут n чисел исходного набора A[1] A[2]
... A[n]
(1 ≤ A[i]
≤ 50).
Окончание тестов - число 0 в отдельной строке.
Выходные данные
Для каждого теста выведите ответ в отдельной строке минимально возможное количество шагов для нахождения НОД.