Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/34: Рейтинг темы: голосов - 34, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 16.02.2018
Сообщений: 8

Нахождение дискриминанта

16.02.2018, 11:15. Показов 7361. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Делал программу на нахождение дискриминанта и тут встал в ступор. Дело в том что квадрат D находится как 21 ... и т.д нереально больщое число что - то в районе 21 миллиона. Мб поможете?

C++
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
// Подключаем нужные библиотеки
#include "stdafx.h"
#include <iostream>
#include <math.h>
#include <locale>
using namespace std;
 
 
int main() {
 
    int a, b, c, D, stp;
    float  x1, x2;
    // Ставим русскую локализацию
    setlocale(LC_ALL, "Russian");
 
    cout << "Введи x в квадрате \n";
    cin >> a;
    cout << "Введи x \n";
    cin >> b;
    cout << "Введи число \n";
    cin >> c;
    D = pow(b, stp = 2) - 4 * a * c;
    cout << " Дискриминант равен " << D;
    if (D < 0) {
        cout << "Уравнение не имеет корня т.к дискриминант меньше 0" << endl;
        exit;
    }
    else if (D > 0) {
        x1 = sqrt(D);
      cout << " x1 равен = " << x1 << endl;    
    }
      
    system("pause");
    
}
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.02.2018, 11:15
Ответы с готовыми решениями:

Нахождение дискриминанта через указатели и ссылки
Имеется вот такой код #include &lt;iostream&gt; #include &lt;math.h&gt; using namespace std; int menu() { int choose; cout...

Вычисление дискриминанта
Вроди простая программа но почему то работает некоректно не пойму в чем причина С++ #include &quot;stdafx.h&quot; #include...

Вычисление дискриминанта
Не работает программа. Подскажите, что не так.#include &lt;QTextStream&gt; #include&lt;iostream&gt; #include&lt;math.h&gt; using namespace std; ...

7
1617 / 1182 / 553
Регистрация: 08.01.2012
Сообщений: 4,560
16.02.2018, 12:41
Лучший ответ Сообщение было отмечено HOLODniK как решение

Решение

C++
1
D = b*b - 4 * a * c;//pow(b,2)
0
Диссидент
Эксперт C
 Аватар для Байт
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
16.02.2018, 12:44
HOLODniK, Используй double вместо int. О float вообще забудь. И что мешает вместо pow(b. 2.0) написать b*b ?
Кстати, дискриминант - это именно b2 - ac, а вовсе не корень из него.
1
 Аватар для COKPOWEHEU
4083 / 2681 / 432
Регистрация: 09.09.2017
Сообщений: 11,910
16.02.2018, 13:50
Code
1
2
3
4
5
6
7
8
$ g++ main.c -Wall
main.c: In function ‘int main()’:
main.c:24:13: warning: statement is a reference, not call, to function ‘exit’ [-Waddress]
         exit;
             ^
main.c:24:13: warning: statement has no effect [-Wunused-value]
main.c:10:16: warning: unused variable ‘x2’ [-Wunused-variable]
     float  x1, x2;
Code
1
2
3
4
5
6
7
$ ./a.out 
Введи x в квадрате 
1 6 8
Введи x 
Введи число 
 Дискриминант равен 4 x1 равен = 2
sh: 1: pause: not found
Как воспроизвести ошибку?
Ну, то есть понятно, что корни пока не считаются, но и неприличных дискриминантов вроде не вылезает
0
0 / 0 / 0
Регистрация: 16.02.2018
Сообщений: 8
16.02.2018, 19:37  [ТС]
Крч у меня проблема именно с корнем. Поэтому остальную часть дискриминанта я и не находил

Добавлено через 1 минуту
Хм... Ты попробуй с - дискриминантом. Там-то всё к чертям и покатится

Добавлено через 36 секунд
D = b*b - 4*a*c

Добавлено через 3 минуты
Я заменил pow на b * b и получилось
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
16.02.2018, 21:25
Цитата Сообщение от HOLODniK Посмотреть сообщение
Крч у меня проблема именно с корнем.
при нахождении дискриминанта корень (см. сообщение от Байт) не требуется.
сбросьте оригинал условия задачи
0
0 / 0 / 0
Регистрация: 16.02.2018
Сообщений: 8
17.02.2018, 09:07  [ТС]
Но при нахождении x1 x2 надо

Добавлено через 13 минут
Я написал в теме неверно, x1 x2 ненормально находятся
0
 Аватар для COKPOWEHEU
4083 / 2681 / 432
Регистрация: 09.09.2017
Сообщений: 11,910
17.02.2018, 11:59
Цитата Сообщение от HOLODniK Посмотреть сообщение
else if (D > 0) { x1 = sqrt(D); cout << " x1 равен = " << x1 << endl;
Вот это - явно не нахождение корня уравнения. В нем помимо корня из дискриминанта должны учитываться еще коэффициенты A и В.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
17.02.2018, 11:59
Помогаю со студенческими работами здесь

Вычислить x1 (и x2) с помощью дискриминанта
Создать приложение для вычисления x1 (и x2) с помощью дискриминанта. Вычисления реализовать в отдельной функции.

Программа для вычисления дискриминанта, пишет ошибку
#include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;locale&gt; using namespace std; int _tmain() { setlocale(LC_ALL, &quot;&quot;); ...

Составить программу для решения квадратного уравнения методом дискриминанта.
Составить программу для решения квадратного уравнения методом дискриминанта.

Поиск дискриминанта, АТД "Квадратное уравнение"
нужно создать АТД квадратное уравнение, с выводом корней и самого уравнения на экран. Вывод уравнения, вроде, проходит нормально, а вот...

Поменять нахождение min среди двумерного массива, на нахождение min в каждой сточке
Поменять нахождение min среди двумерного массива, на нахождение min в каждой сточке #include &lt;iostream&gt; #include &lt;cstddef&gt; ...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru