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

Не могу найти ошибку - C++

Восстановить пароль Регистрация
 
BoND1k
0 / 0 / 0
Регистрация: 28.10.2013
Сообщений: 5
28.10.2013, 21:40     Не могу найти ошибку #1
В общем суть программы состоит в том чтобы решить нелинейное уравнение x3+x2-4x-4=0 двумя методами хорд и итераций, есть исходник , вот только не могу понять почему не считает, пишет что отрезок не подходит, хотя все правильно вроде бы... Помогите найти ошибку, пожалуйста!
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
69
70
71
72
73
74
75
76
77
78
79
#include "stdafx.h"
#include <iostream>
#include <math.h>
 
using namespace std;
 
float FF (float x)
    {return powf(x,3)+powf(x,2)-4*x-4;}
 
float PF (float x) 
    {return 3+powf(x,2)-4;}
 
float FI (float x) 
    {return (-powf(x,3)+powf(x,2)-4*x-4)/29;}
 
float hordi (float a, float b)
    {
        float x=a,x1=b,x2=a, f1,f2,f=FF(x);
        int i=0;
        while (abs(f) > 0.001)
        {
            i++;
            f1=FF(x1);
            f2=FF(x2);
            x=x2-f2*(x1-x2)/(f1-f2);
            f=FF(x);
            x1=x2;
            x2=x;
        }
        cout<<"x= "<<x<<" kol-vo iteraciy: "<<i<<endl;
        return 0;}
 
float iter (float a, float b)
    {
        int i=0;
        float f=PF(b);
        if (f<=0) {cout<<"Otrezok ne podhodit1\n";}
        else
            {
                int min, max;
                min=PF(a);
                if (abs(f)>abs(min)) 
                    max=abs(f);
                else { 
                    max=abs(min);
                    min=abs(f);}
                float q=1-min/max;
                if (q>1) {cout<<"Otrezok ne podhodit\n";}
                else {
                    float x=FI(a), y=FF(x);
                    while (abs(y)>0.001) {
                        i++;
                        x=FI(x);
                        y=FF(x);
                    }
                    cout<<"x= "<<x<<" kol-vo iteraciy: "<<i<<endl;
            }}
        return 0;}
 
int _tmain(int argc, _TCHAR* argv[])
{
    cout<<"Metod hord:\n";
    cout<<"Otrezok [2,0]\n";
    hordi(2,0);
    cout<<"Otrezok [-1,0]\n";
    hordi(-1,0);
    cout<<"Otrezok [-2,0]\n";
    hordi(-2,0);
    cout<<"Metod iteratciy:\n";
    cout<<"Otrezok [2,0]:\n";
    iter(2,0);
    cout<<"Otrezok [-1,0]:\n";
    iter(-1,0);
    cout<<"Otrezok [-2,0]:\n";
    iter(-2,0);
    cin.get();
    
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.10.2013, 21:40     Не могу найти ошибку
Посмотрите здесь:

Не могу найти ошибку C++
C++ Не могу найти ошибку
C++ не могу найти ошибку
C++ Не могу найти ошибку...
C++ Не могу найти ошибку
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
UVEN
3 / 3 / 0
Регистрация: 19.02.2013
Сообщений: 26
28.10.2013, 21:47     Не могу найти ошибку #2
Давайте по порядку.

Пишет так, потому что

C++
1
2
3
4
       
        int i=0;
        float f=PF(b);
        if (f<=0) {cout<<"Otrezok ne podhodit1\n";} // число f меньше нуля
Вопрос такой . Что это за функция PF ?
BoND1k
0 / 0 / 0
Регистрация: 28.10.2013
Сообщений: 5
28.10.2013, 22:04  [ТС]     Не могу найти ошибку #3
Добавлено через 5 минут
Цитата Сообщение от UVEN Посмотреть сообщение
Давайте по порядку.

Пишет так, потому что

C++
1
2
3
4
       
        int i=0;
        float f=PF(b);
        if (f<=0) {cout<<"Otrezok ne podhodit1\n";} // число f меньше нуля
Вопрос такой . Что это за функция PF ?
функция PF- это производная от функции FF
UVEN
3 / 3 / 0
Регистрация: 19.02.2013
Сообщений: 26
28.10.2013, 22:05     Не могу найти ошибку #4
C++
1
2
3
4
5
float FF (float x)
    {return powf(x,3)+powf(x,2)-4*x-4;}
 
float PF (float x) 
    {return 3*powf(x,2)+2*x-4;}   // Производная
Поправите свой код..
BoND1k
0 / 0 / 0
Регистрация: 28.10.2013
Сообщений: 5
29.10.2013, 00:22  [ТС]     Не могу найти ошибку #5
Цитата Сообщение от UVEN Посмотреть сообщение
C++
1
2
3
4
5
float FF (float x)
    {return powf(x,3)+powf(x,2)-4*x-4;}
 
float PF (float x) 
    {return 3*powf(x,2)+2*x-4;}   // Производная
Поправите свой код..
Спасибо подправил, но все равно почему то отрезок не подходит
UVEN
3 / 3 / 0
Регистрация: 19.02.2013
Сообщений: 26
29.10.2013, 01:13     Не могу найти ошибку #6
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
69
70
71
72
73
74
75
#include <iostream>
#include <math.h>
 
using namespace std;
 
float FF (float x)
    {return powf(x,3)+powf(x,2)-4*x-4;}
 
float PF (float x)
    {return 3+powf(x,2)-4;}
 
 
 
float hordi (float a, float b)
    {
        float x=a,x1=b,x2=a, f1,f2,f=FF(x);
        int i=0;
        while (abs(f) > 0.001)
        {
            i++;
            f1=FF(x1);
            f2=FF(x2);
            x=x2-f2*(x1-x2)/(f1-f2);
            f=FF(x);
            x1=x2;
            x2=x;
        }
        cout<<"x= "<<x<<" kol-vo iteraciy: "<<i<<endl;
        return 0;}
 
float iter (float a, float b)
    {
        int i=0;
        float f=PF(a);
   //       if (f<=0) {cout<<"Otrezok ne podhodit1\n";}
  //        else
            {
                int min, max;
                min=PF(a);
                if (abs(f)>abs(min))
                    max=abs(f);
                else {
                    max=abs(min);
                    min=abs(f);}
                {
                    float x=a, y=FF(x);
                    while (abs(y)>0.001)
                    {
                    x=x-FF(x)*(1/PF(x));
                    y=FF(x);
                    }
                    cout<<"x= "<<x<<" kol-vo iteraciy: "<<i<<endl;
            }}
        return 0;}
 
int _tmain(int argc, _TCHAR* argv[])
{
    cout<<"Metod hord:\n";
    cout<<"Otrezok [2,0]\n";
    hordi(2,0);
    cout<<"Otrezok [-1,0]\n";
    hordi(-1,0);
    cout<<"Otrezok [-2,0]\n";
    hordi(-2,0);
    cout<<"Metod iteratciy:\n";
    cout<<"Otrezok [2,0]:\n";
    iter(2,0);
    cout<<"Otrezok [-1,0]:\n";
    iter(-1,0);
    cout<<"Otrezok [-2,0]:\n";
    iter(-2,0);
    cin.get();
 
    return 0;
}
UVEN
3 / 3 / 0
Регистрация: 19.02.2013
Сообщений: 26
29.10.2013, 01:17     Не могу найти ошибку #7
Картинка работы вашей программы во влажении
Миниатюры
Не могу найти ошибку  
MrGluck
29.10.2013, 01:32
  #8

Не по теме:

Цитата Сообщение от UVEN Посмотреть сообщение
влажении
от слова влажность?

BoND1k
0 / 0 / 0
Регистрация: 28.10.2013
Сообщений: 5
29.10.2013, 01:52  [ТС]     Не могу найти ошибку #9
Цитата Сообщение от UVEN Посмотреть сообщение
Картинка работы вашей программы во влажении
спасибо за помощь, но вот я не могу понять а нули вообще возможны в данном решении??
UVEN
3 / 3 / 0
Регистрация: 19.02.2013
Сообщений: 26
29.10.2013, 02:17     Не могу найти ошибку #10
таки да, от него

Добавлено через 12 минут
Ноль как ответ ?.. Возможен.. Только функция должна пересекать ось абсцисс при значении аргумента равным 0
например линейная функция 4*x
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
29.10.2013, 18:45     Не могу найти ошибку
Еще ссылки по теме:

C++ Не могу найти ошибку
Не могу найти ошибку C++

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

Или воспользуйтесь поиском по форуму:
BoND1k
0 / 0 / 0
Регистрация: 28.10.2013
Сообщений: 5
29.10.2013, 18:45  [ТС]     Не могу найти ошибку #11
то есть данное решения является правильным?
Yandex
Объявления
29.10.2013, 18:45     Не могу найти ошибку
Ответ Создать тему
Опции темы

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