Aktualizovat du2/program.c
This commit is contained in:
parent
e382f4f331
commit
6ea1690652
@ -1,61 +1,86 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <ctype.h>
|
||||
|
||||
void evaluate_polynomial(double x, double *coefficients, int n) {
|
||||
double result = coefficients[0];
|
||||
// Проверка, является ли строка числом (целым или с плавающей точкой)
|
||||
int je_cislo(const char *str) {
|
||||
char *endptr;
|
||||
strtod(str, &endptr);
|
||||
return *endptr == '\0';
|
||||
}
|
||||
|
||||
// Применение метода Хорнера
|
||||
for (int i = 1; i < n; i++) {
|
||||
result = result * x + coefficients[i];
|
||||
// Чтение числа с проверкой, если ошибка — вывод сообщения и завершение программы
|
||||
double citaj_cislo(int poradie) {
|
||||
char buffer[100];
|
||||
if (fgets(buffer, sizeof(buffer), stdin) == NULL) {
|
||||
if (poradie == 0) {
|
||||
fprintf(stderr, "Chyba: Nepodarilo sa nacitat hodnotu x.\n");
|
||||
} else {
|
||||
fprintf(stderr, "Chyba: Nepodarilo sa nacitat koeficient c.%d.\n", poradie);
|
||||
}
|
||||
exit(1);
|
||||
}
|
||||
|
||||
// Округление результата до двух знаков после запятой
|
||||
printf("Vysledok je: %.2f\n", result);
|
||||
// Убираем перевод строки
|
||||
char *newline = strchr(buffer, '\n');
|
||||
if (newline) *newline = '\0';
|
||||
|
||||
// Пустая строка — конец ввода коэффициентов
|
||||
if (buffer[0] == '\0') {
|
||||
return 0.0 / 0.0; // Возвращаем NaN как сигнал конца ввода
|
||||
}
|
||||
|
||||
if (!je_cislo(buffer)) {
|
||||
if (poradie == 0) {
|
||||
fprintf(stderr, "Chyba: Nepodarilo sa nacitat hodnotu x.\n");
|
||||
} else {
|
||||
fprintf(stderr, "Chyba: Nepodarilo sa nacitat koeficient c.%d.\n", poradie);
|
||||
}
|
||||
exit(1);
|
||||
}
|
||||
|
||||
return atof(buffer);
|
||||
}
|
||||
|
||||
// Горнерова схема
|
||||
double hornerova_schema(double *koef, int n, double x) {
|
||||
double vysledok = 0.0;
|
||||
for (int i = 0; i < n; i++) {
|
||||
vysledok = vysledok * x + koef[i];
|
||||
}
|
||||
return vysledok;
|
||||
}
|
||||
|
||||
int main() {
|
||||
double x;
|
||||
double koef[100]; // максимум 100 коэффициентов, можно увеличить при необходимости
|
||||
int n = 0;
|
||||
|
||||
// Ввод значения x
|
||||
if (scanf("%lf", &x) != 1) {
|
||||
printf("Chyba: Neplatne x\n");
|
||||
return 1;
|
||||
}
|
||||
|
||||
// Преобразование запятой в точку в числе
|
||||
char c;
|
||||
while ((c = getchar()) != '\n' && c != EOF) {
|
||||
if (c == ',') {
|
||||
ungetc('.', stdin); // Заменяем запятую на точку
|
||||
} else {
|
||||
ungetc(c, stdin);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
double coefficients[100]; // Массив для коэффициентов полинома
|
||||
// Чтение x
|
||||
x = citaj_cislo(0);
|
||||
|
||||
// Чтение коэффициентов
|
||||
while (1) {
|
||||
if (scanf("%lf", &coefficients[n]) != 1) {
|
||||
if (n == 0) {
|
||||
printf("Nepodarilo sa nacitat polynom na 2 mieste.\n");
|
||||
return 1;
|
||||
}
|
||||
break; // Прекращаем чтение, если введены все коэффициенты
|
||||
double koeficient = citaj_cislo(n + 1);
|
||||
if (koeficient != koeficient) { // Если NaN, это конец ввода
|
||||
break;
|
||||
}
|
||||
koef[n++] = koeficient;
|
||||
|
||||
if (n >= 100) {
|
||||
fprintf(stderr, "Chyba: Prilis vela koeficientov.\n");
|
||||
exit(1);
|
||||
}
|
||||
n++;
|
||||
}
|
||||
|
||||
// Если не было введено хотя бы одного коэффициента
|
||||
if (n == 0) {
|
||||
printf("Chyba: Nebyly zadany koeficienty\n");
|
||||
fprintf(stderr, "Chyba: Neboli zadane ziadne koeficienty.\n");
|
||||
return 1;
|
||||
}
|
||||
|
||||
// Вызов функции для вычисления полинома
|
||||
evaluate_polynomial(x, coefficients, n);
|
||||
// Вычисление и вывод результата
|
||||
double vysledok = hornerova_schema(koef, n, x);
|
||||
printf("Vysledok je: %.2f\n", vysledok);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user