0 / 0 / 0
Регистрация: 03.06.2012
Сообщений: 14
1

[страуструп] задача на нахождение корней кв ур-я , проверьте пожалуйста

06.12.2013, 17:03. Показов 635. Ответов 4
Метки нет (Все метки)

Здравствуйте, в книге Страуструпа "Основы и принципы программирования" есть задача на нахождение корней кв. ур-я, я её написал, но терминал выдает такое - http://puu.sh/5DQV0.png , я так понимаю , что проблема с типами double/int , может кто сказать что не так?

директива "std_lib_facilities.h" дана из книги, функция "keep_window_open" оттуда же

вот код:

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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
#include "../../std_lib_facilities.h"
 
int a;
int b;
int c;
double D;
 
 
// Нахождение дискриминанта
double reshaem_D()
{
    return D=(b^2)-(4*a*c);
}
 
// Нахождение 1го корня для дискриминанта > 0
double reshaem_D_polozh_1(double x)
{
    return x=((-b) + sqrt((b^2)-(4*a*a))) / (2*a);
}
 
// Нахождение 2го корня для дискриминанта > 0
double reshaem_D_polozh_2(double x)
{
    return x=((-b) - sqrt((b^2)-(4*a*a))) / (2*a);
}
 
// Нахождение корня для дискриминанта = 0
double reshaem_D_nol(double x)
{
    return x=(-b)/(2*a);
}
 
 
 
int main()
{
    int a = 0;
    int b = 0;
    int c = 0;
    double x = 0;
    double D = 0;
 
    //Вводим a,b,c
    cout << "Uravnenie imeet vid: a*x^2 + b*x + c = 0, vvedite a,b,c dlya resheniya uravneniya" << endl;
    cout << "Vvedite a= "; cin>> a; cout << "Vvedite b= ";cin>> b; cout << "Vvedite c= ";cin>> c;
 
    //Вычисляем дискриминант 
    reshaem_D();
 
    //Проверяем дискриминант, D>0;D<0;D=0
    if (reshaem_D>0)
    {
        reshaem_D_polozh_1(x);
        reshaem_D_polozh_2(x);
        cout << "Korni uravneniya x1= " << reshaem_D_polozh_1(x) << " x2= " << reshaem_D_polozh_2(x) << endl;
    }
    else if (reshaem_D<0)
    {
        cout << "Net reshenii" << endl;
    }
    else if (reshaem_D==0)
    {
        reshaem_D_nol(x);
        cout << "Korni uravneniya x= " << reshaem_D_nol << endl;
    }
 
    keep_window_open();
}
__________________
Помощь в написании контрольных, курсовых и дипломных работ, диссертаций здесь
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
06.12.2013, 17:03
Ответы с готовыми решениями:

Страуструп, "Принципы и практика использования С++": задача на нахождение моды
Здравствуйте ,решаю упражнения из книги &quot;Страуструп принципы и практика использования c++&quot;,...

Нахождение первообразной (проверьте пожалуйста)
Для функции у=х/(х-1)^2 найдите первообразную. У меня получилось F(x)=Ln-1/(x-1) +C

Задача с шарами. Проверьте, пожалуйста
Здравствуйте! Проверьте, пожалуйста. Решения верны? P.S.: Тему назвала не правильно. Здесь 2...

Проверьте мои решения задач на правильность, пожалуйста.(4)(Интересная задача!)
/*На предмете мы отталкиваемся от понятия &quot;один бит - это количество информации, что уменьшает...

4
1404 / 646 / 135
Регистрация: 11.08.2011
Сообщений: 2,299
Записей в блоге: 2
06.12.2013, 17:06 2
b^2 <---- не то.
b*b <---- то.
0
0 / 0 / 0
Регистрация: 03.06.2012
Сообщений: 14
06.12.2013, 17:13  [ТС] 3
Цитата Сообщение от Dani Посмотреть сообщение
b^2 <---- не то.
b*b <---- то.
Исправил, спасибо, но теперь такое - http://puu.sh/5DRxd.png
0
51 / 51 / 21
Регистрация: 08.02.2013
Сообщений: 189
06.12.2013, 17:14 4
Дискриминант находите в отдельной функции:
C++
1
2
3
4
5
// Нахождение дискриминанта
double reshaem_D()
{
    return D=(b^2)-(4*a*c);
}
В фунции для нахождения корней:
C++
1
2
3
4
5
6
7
8
9
10
11
// Нахождение 1го корня для дискриминанта > 0
double reshaem_D_polozh_1(double x)
{
    return x=((-b) + sqrt((b^2)-(4*a*a))) / (2*a);
}
 
// Нахождение 2го корня для дискриминанта > 0
double reshaem_D_polozh_2(double x)
{
    return x=((-b) - sqrt((b^2)-(4*a*a))) / (2*a);
}
лучше передать еще и второй аргумент - дискриминант, уже вычисленный, чтобы не переписывать, громоздкое выражение.
Вы его переписали, и как следствие допустили ошибку, дискриминант считается правильно как:
C++
1
D = b*b - 4*a*c;
а не, как у вас
C++
1
D = b*b - 4*a*a;
0
1404 / 646 / 135
Регистрация: 11.08.2011
Сообщений: 2,299
Записей в блоге: 2
06.12.2013, 17:21 5
Много ошибок в коде. Мне лень искать все ошибки, вот
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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
#include <iostream>
#include <cmath>
 
using namespace std;
 
int a;
int b;
int c;
double D;
 
 
// Нахождение дискриминанта
void reshaem_D()
{
    D = ((b*b)-(4*a*c));
}
 
// Нахождение 1го корня для дискриминанта > 0
double reshaem_D_polozh_1(double x)
{
    return ((-b) + sqrt((b*b)-(4*a*a))) / (2*a);
}
 
// Нахождение 2го корня для дискриминанта > 0
double reshaem_D_polozh_2(double x)
{
    return ((-b) - sqrt((b*b)-(4*a*a))) / (2*a);
}
 
// Нахождение корня для дискриминанта = 0
double reshaem_D_nol(double x)
{
    return x=(-b)/(2*a);
}
 
 
 
int main()
{
    double x = 0;
 
    //Вводим a,b,c
    cout << "Uravnenie imeet vid: a*x^2 + b*x + c = 0, vvedite a,b,c dlya resheniya uravneniya" << endl;
    cout << "Vvedite a= "; cin>> a; cout << "Vvedite b= ";cin>> b; cout << "Vvedite c= ";cin>> c;
 
    //Вычисляем дискриминант 
    reshaem_D();
 
    //Проверяем дискриминант, D>0;D<0;D=0
    if (D>0)
    {
        reshaem_D_polozh_1(x);
        reshaem_D_polozh_2(x);
        cout << "Korni uravneniya x1= " << reshaem_D_polozh_1(x) << " x2= " << reshaem_D_polozh_2(x) << endl;
    }
    else if (D<0)
    {
        cout << "Net reshenii" << endl;
    }
    else if (D==0)
    {
        reshaem_D_nol(x);
        cout << "Korni uravneniya x= " << reshaem_D_nol << endl;
    }
 
}
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
06.12.2013, 17:21
Помогаю со студенческими работами здесь

Задача:Страуструп. 4.11.4
1.Напишите программу,которая печатает символы от 'a' до 'z' и цифры от '0' до '9' и их целые...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2022, CyberForum.ru