Привет Я пытаюсь написать код на C, чтобы найти GCD для более чем двух чисел. Однако, когда я компилирую и запускаю код, GCD всегда равен 0. Пойми, если кто-нибудь сможет помочь. Спасибо.Поиск GCD с использованием массивов в C
#include <stdio.h>
static int gcd(int x, int y)
{
int r;
if (x <= 0 || y <= 0)
return 0;
while ((r = x % y) != 0)
{
x = y;
y = r;
}
return y;
}
int main (void)
{
int A[5];
int g = A[0];
int i;
int n;
printf ("How many elements are there? \n")
scanf ("%d", &n);
printf ("Input the elements. \n");
for (i = 0; i < n; i++)
{
scanf ("%d", &A[i]);
}
for (i = 1; i < n; i++)
g = gcd(g, A[i]);
printf ("GCD is: %d \n");
return 0;
}
Вы забыли задать вопрос. Какая помощь вам нужна? Вы пытались добавить журнал? Вы пытались использовать отладчик? На что ты застрял? –
int g = A [0]; второй оператор внутри основной функции, имеет ли смысл? Вы назначаете значение мусора в переменной g. –