From 7be208152cd0962d2b6940d55891016c4a792abe Mon Sep 17 00:00:00 2001 From: Denys Sanchuk Date: Tue, 25 Feb 2025 14:09:29 +0000 Subject: [PATCH] =?UTF-8?q?=D0=9E=D0=B1=D0=BD=D0=BE=D0=B2=D0=B8=D1=82?= =?UTF-8?q?=D1=8C=20du2/program.c?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- du2/program.c | 64 +++++++++++++++++++++++++++------------------------ 1 file changed, 34 insertions(+), 30 deletions(-) diff --git a/du2/program.c b/du2/program.c index d069e2d..6e02a12 100644 --- a/du2/program.c +++ b/du2/program.c @@ -1,38 +1,42 @@ #include #include -#define MAX_SIZE 50 +void evaluate_polynomial(double x, double *coefficients, int n) { + double result = coefficients[0]; -int main() { - double x, coefficient, result = 0.0; - int count = 0; - double coefficients[MAX_SIZE]; - - if (scanf("%lf", &x) != 1) { - printf("Chyba: Hodnota pre x nebola nacitana.\n"); - return 1; - } - - while (count < MAX_SIZE) { - if (scanf("%lf", &coefficient) != 1) { - if (feof(stdin)) break; // Конец файла - завершаем чтение - printf("Nepodarilo sa nacitat polynom na %d mieste.\n", count + 1); - return 1; - } - coefficients[count++] = coefficient; - } - - if (count == 0) { - printf("Chyba: Koeficient nebol nacitany.\n"); - return 1; - } - - result = coefficients[0]; - for (int i = 1; i < count; i++) { + // Применение метода Хорнера + for (int i = 1; i < n; i++) { result = result * x + coefficients[i]; } - - printf("Vysledok je: %.2lf\n", result); - + + printf("Vysledok je: %.2f\n", result); +} + +int main() { + double x; + int n = 0; + + // Ввод значения x + if (scanf("%lf", &x) != 1) { + printf("Chyba: Neplatne x\n"); + return 1; + } + + double coefficients[100]; // Массив для коэффициентов полинома + + // Чтение коэффициентов + while (scanf("%lf", &coefficients[n]) == 1) { + n++; + } + + // Если нет коэффициентов + if (n == 0) { + printf("Chyba: Nebyly zadany koeficienty\n"); + return 1; + } + + // Вызов функции для вычисления полинома + evaluate_polynomial(x, coefficients, n); + return 0; }