Форум программистов, компьютерный форум CyberForum.ru

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

Восстановить пароль Регистрация
 
tyan
 Аватар для tyan
0 / 0 / 0
Регистрация: 03.06.2012
Сообщений: 14
06.12.2013, 17:03     [страуструп] задача на нахождение корней кв ур-я , проверьте пожалуйста #1
Здравствуйте, в книге Страуструпа "Основы и принципы программирования" есть задача на нахождение корней кв. ур-я, я её написал, но терминал выдает такое - 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();
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
06.12.2013, 17:03     [страуструп] задача на нахождение корней кв ур-я , проверьте пожалуйста
Посмотрите здесь:

C++ Задача:Страуструп. 4.11.4
Нахождение корней квадратного уравнения C++
Нахождение корней уравнения C++
C++ Нахождение корней полинома n-ой степени
Нахождение корней уравнения C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Dani
1263 / 621 / 50
Регистрация: 11.08.2011
Сообщений: 2,236
Записей в блоге: 2
Завершенные тесты: 1
06.12.2013, 17:06     [страуструп] задача на нахождение корней кв ур-я , проверьте пожалуйста #2
b^2 <---- не то.
b*b <---- то.
tyan
 Аватар для tyan
0 / 0 / 0
Регистрация: 03.06.2012
Сообщений: 14
06.12.2013, 17:13  [ТС]     [страуструп] задача на нахождение корней кв ур-я , проверьте пожалуйста #3
Цитата Сообщение от Dani Посмотреть сообщение
b^2 <---- не то.
b*b <---- то.
Исправил, спасибо, но теперь такое - http://puu.sh/5DRxd.png
Extrim88
 Аватар для Extrim88
50 / 50 / 11
Регистрация: 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;
Dani
1263 / 621 / 50
Регистрация: 11.08.2011
Сообщений: 2,236
Записей в блоге: 2
Завершенные тесты: 1
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;
    }
 
}
Yandex
Объявления
06.12.2013, 17:21     [страуструп] задача на нахождение корней кв ур-я , проверьте пожалуйста
Ответ Создать тему
Опции темы

Текущее время: 21:34. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru