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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
BoND1k
0 / 0 / 0
Регистрация: 28.10.2013
Сообщений: 5
#1

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

28.10.2013, 21:40. Просмотров 405. Ответов 10
Метки нет (Все метки)

В общем суть программы состоит в том чтобы решить нелинейное уравнение 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++
#include &lt;iostream&gt; using namespace std; void obr1(char **s, char **mas, int n, int m) { int i; int k; char *tm; for(i...

Массивы. Посчитать количество положительных, найти минимальное, удалить строку с минимальным (Не могу найти ошибку) - C++
// Заданы матрицы X(8;4),Y(5;5),Z(6;9). // Для каждой из матриц определить строку, в которой находится наименьшее // количество...

Не могу найти ошибку - C++
НЕ могу найти ошибку где он не правильно считае, норма матрици прикреплена в виде фото Код тут #include &lt;cstdlib&gt; #include...

Не могу найти ошибку - C++
Осуществить циклический сдвиг квадратной матрицы размерности NxN вправо на N элементов таким образом: элементы 1-й строки сдвигаются в...

Не могу найти ошибку - C++
fatal error LNK1120: неразрешенных внешних элементов: 1 #include &lt;iostream&gt; #include &lt;cstring&gt; #include &lt;thread&gt; using namespace...

Не могу найти ошибку! - C++
#include &lt;iostream.h&gt; int main() { cout &lt;&lt; &quot;Hello there.\n&quot;; cout &lt;&lt; &quot;Here is 5:&quot; &lt;&lt; 5 &lt;&lt; &quot;\n&quot;; cout &lt;&lt; &quot;The manipulator end1...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
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
BoND1k
0 / 0 / 0
Регистрация: 28.10.2013
Сообщений: 5
29.10.2013, 18:45  [ТС] #11
то есть данное решения является правильным?
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
29.10.2013, 18:45
Привет! Вот еще темы с ответами:

Не могу найти ошибку - C++
ошибка в строке 24..не могу исправить. Помогите, пожалуйста. #include &lt;math.h&gt; #include &lt;stdio.h&gt; #include &lt;iostream&gt; using...

Не могу найти ошибку - C++
Уважаемые форумчане! Скорее всего моя ошибка опять глупая, но я просто не могу её понять. Самое странное что он даже просто ввести строку...

Не могу найти ошибку - C++
#include &quot;stdafx.h&quot; #include &lt;conio.h&gt; class Sum { public: int sum1 (int x1, int x2) { return x1 + x2; ...

Не могу найти ошибку - C++
Сумму элементов последовательности, расположенных между первым и вторым положительными элементами. При помощи итераторов. Если нету...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
29.10.2013, 18:45
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru