Форум программистов, компьютерный форум, киберфорум
Python: Решение задач
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/11: Рейтинг темы: голосов - 11, средняя оценка - 5.00
5 / 5 / 1
Регистрация: 23.11.2022
Сообщений: 13

Квадратное уравнение и ошибка "Ошибка представления (PE)"

28.11.2022, 05:09. Показов 2941. Ответов 4

Студворк — интернет-сервис помощи студентам
Есть задание :
Формат ввода
Вводится 3 вещественных числа a, b, c — коэффициенты уравнения вида:
a*x^2+b*x+c=0

Формат вывода
Если у уравнения нет решений — следует вывести «No solution».
Если корней конечное число — их нужно вывести через пробел в порядке возрастания с точностью до сотых.
Если корней неограниченное число — следует вывести «Infinite solutions».

Примечание
Обратите внимание, что ограничения на значения коэффициентов отсутствуют

Пример 1
Ввод
1
-2
1
Вывод
1.00

Пример 2
Ввод
3.5
-2.4
-7.3
Вывод
-1.14 1.83


Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
a = float(input())
b = float(input())
c = float(input())
x1 = 0
x2 = 0
disc = ((b ** 2) - (4 * a * c))  # discriminant
if a == 0:  # or a == b == c == 0: # is it correct ?
    print("Infinite solutions")
elif disc < 0:
    print("No solution")
elif disc == 0:
    x1 = -b / (2 * a)
    print("%.2f" % x1)
elif disc > 0:
    x1 = ((-b) - (disc ** 0.5)) / (2 * a)
    x2 = ((-b) + (disc ** 0.5)) / (2 * a)
    print(min("%.2f" % x1, "%.2f" % x2), max("%.2f" % x1, "%.2f" % x2), sep=" ")
elif c == 0 and a != 0:
    x1 = 0
    x2 = -b / a
    print(min("%.2f" % x1, "%.2f" % x2), max("%.2f" % x1, "%.2f" % x2), sep=" ")
elif b == 0 and a != 0:
    x1 = (-c / a) ** 0.5
    x2 = -(-c / a) ** 0.5
    print(min("%.2f" % x1, "%.2f" % x2), max("%.2f" % x1, "%.2f" % x2), sep=" ")

Проходит 3 теста и следующий же с ошибкой : Presentation error(PE)
Тестирующая система не может проверить выходные данные, так как их формат не соответствует описанному в условиях задачи
Причины: 1. неверный формат вывода 2. программа не печатает результат 3. лишний вывод
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
28.11.2022, 05:09
Ответы с готовыми решениями:

Квадратное уравнение, где ошибка?
#include &quot;stdafx.h&quot; #include &quot;iostream&quot; #include &quot;math.h&quot; using namespace std; int main() { setlocale(0,&quot;&quot;); ...

Ошибка в функции образования нового массива через квадратное уравнение
Добрый день. Имеется следующая функция и компилятор выводит ошибку : error: invalid conversion from ‘int*’ to ‘int’ int Work(int*...

Квадратное уравнение - ошибка "syntax error, unexpected T_VARIABLE"
Помогите пожалуйста, не могу понять, в чем ошибка &quot;syntax error, unexpected T_VARIABLE&quot;, вот код : &lt;?php $a=$_POST; $b=$_POST; ...

4
5516 / 2869 / 571
Регистрация: 07.11.2019
Сообщений: 4,760
28.11.2022, 05:51
Avrandrey, у вас, по крайней мере, одна ошибка: условие в 22 строке, при a=1, b=0, c=1. Должно выдавать: нет решения.
1
Вирусоборец
 Аватар для thyrex
14450 / 7489 / 1582
Регистрация: 06.09.2009
Сообщений: 27,133
28.11.2022, 06:24
Все случаи с а = 0 (линейное уравнение) нужно рассматривать сразу после седьмой строки, а не утверждать о бесконечности количества решений. И только после этого переходить к решению квадратного уравнения.
2
5 / 5 / 1
Регистрация: 23.11.2022
Сообщений: 13
28.11.2022, 17:08  [ТС]
Цитата Сообщение от u235 Посмотреть сообщение
Avrandrey, у вас, по крайней мере, одна ошибка: условие в 22 строке, при a=1, b=0, c=1. Должно выдавать: нет решения.
Спасибо большое, не обратил внимания, исправил (:

Добавлено через 1 минуту
Цитата Сообщение от thyrex Посмотреть сообщение
Все случаи с а = 0 (линейное уравнение) нужно рассматривать сразу после седьмой строки, а не утверждать о бесконечности количества решений. И только после этого переходить к решению квадратного уравнения.
Спасибо большое, попробую выполнить по Вашей рекомендации (:
0
5 / 5 / 1
Регистрация: 23.11.2022
Сообщений: 13
30.11.2022, 01:58  [ТС]
Лучший ответ Сообщение было отмечено u235 как решение

Решение

UPD.Итог2.0:

Примитивная ликвидация %f форматтера спасла ситуацию и код прошёл все тесты, после чего на пол экрана проявилась табличка с зелёным шрифтом "Решена полностью". Спасибо всем причастным к решению моей проблемы! Задачу требовалось решить зная лишь 3 типа данных, условные и логические операторы - задача выполнена. Рабочий код ниже в двух вариантах:

Вариант №1:

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
a = float(input())
b = float(input())
c = float(input())
x1 = float(0.00)
x2 = float(0.00)
if a == 0 and b == 0 and c == 0:
    print("Infinite solutions")
elif a == 0 and b != 0 and c != 0:
    x1 = -(c / b)
    print(x1)
elif a == 0 and b == 0 and c != 0:
    print("No solution")  # no sol
elif a == 0 and b != 0 and c == 0:
    x1 = 0
    print(x1)
elif b == 0 and c == 0 and a != 0:
    x1 = 0
    print(x1)
elif c == 0 and b != 0 and a != 0:
    x1 = 0
    x2 = -(b / a)
    print(min(x1, x2), max(x1, x2), sep=' ')
elif b == 0 and a != 0 and c != 0:
    if (-(c / a)) < 0:
        print("No solution")
    else:
        x1 = (-c / a) ** 0.5
        x2 = -((-c / a) ** 0.5)
        print(min(x1, x2), max(x1, x2), sep=' ')
elif a != 0 and b != 0 and c != 0:
    disc = (b ** 2) - (4 * a * c)  # discriminant
    if disc < 0:
        print("No solution")
    elif disc == 0:
        x1 = (-b / (2 * a))
        print("%.2f" % x1)
    elif disc > 0:
        x1 = (-b - (disc ** 0.5)) / (2 * a)
        x2 = (-b + (disc ** 0.5)) / (2 * a)
        print(min(x1, x2), max(x1, x2), sep=' ')

Вариант №2:

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
a = float(input())
b = float(input())
c = float(input())
x1 = float(0.00)
x2 = float(0.00)
if a == 0 and b == 0 and c == 0:
    print("Infinite solutions")
elif a == 0 and b != 0 and c != 0:
    x1 = -(c / b)   
    print(x1)
elif a == 0 and b == 0 and c != 0:
    print("No solution")  # no sol
elif a == 0 and b != 0 and c == 0:
    x1 = 0
    print(x1)
else:
    disc = (b ** 2) - (4 * a * c)  # discriminant
    if disc == 0:
        x1 = (-b) / (2 * a)
        print(x1)
    elif disc > 0:
        x1 = (-b - (disc ** 0.5)) / (2 * a)
        x2 = (-b + (disc ** 0.5)) / (2 * a)
        print(min(x1, x2), max(x1, x2), sep=' ')
    elif disc < 0:
        print("No solution")
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
30.11.2022, 01:58
Помогаю со студенческими работами здесь

Квадратное уравнение методом хорд: ошибка "floating point division by zero"
Квадратное уравнение методом хорд в 102-й строке выбивает ошибку floating point division by zero, никак не могу устранить её, помогите...

Ошибка в программе "квадратное уравнение"
Вот файл MainActivity.java Когда включаю приложение,то пишет ошибка и Force Close Помогите, я новичок, сам не разберусь... ...

Создать производные классы линейное уравнение и квадратное уравнение, в которых данная функция переопределена
Создать абстрактный базовый класс уравнение с виртуальной функцией - корни уравнения. Создать производные классы линейное уравнение и...

Ошибка при создании представления
Есть таблица STUDENTS я делаю запрос в SQL * Plus: SQL&gt; SELECT STUDENTS.MARK, COUNT(*) FROM STUDENTS 2 GROUP BY STUDENTS.MARK ...

Ошибка в представления разреженных матриц
скажите пожалуйста где ошибка Задание такое Использование простых сязанных списков для представления разреженных матриц ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru