Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

Войти
Регистрация
Восстановить пароль
 
takeN
3 / 3 / 1
Регистрация: 22.05.2013
Сообщений: 13
#1

Метод хорд в решении простецкой параболы - C++

03.07.2013, 17:24. Просмотров 337. Ответов 0
Метки нет (Все метки)

Доброго времени суток. При решении, например на промежутке [0,1] выводит количество итераций, равное 9ти, хотя находит корень за 4 итерации. Подскажите что делать и где таится подлянка. Может зацикливается? Хотя показывается один и тот же результат... Вот файлы:
1) файл chords.cpp
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
#include "stdafx.h"
#include "description.h"
#include <iostream>
#include <iomanip>
#include <cmath>
 
using namespace std;
 
void chords(){ 
    int iteration = 0;
    double leftBorder = 0;
    double rightBorder = 0;
    double point = 0;
    double epsilon = 0;
    double radical = 0;
    double border = 0;
    while(true){
        cout<<" Укажите промежуток с корнями уравнения:\n";
            cout<<" Левая граница: "; cin>>leftBorder;
            cout<<" Правая граница: "; cin>>rightBorder;/// correct entry
        if((function(leftBorder))*(function(rightBorder))>=0){
            cout<<" На заданном промежутке либо 2 корня, либо их нет!\n";
            cout<<" Повторите ввод с другими данными...\n\n";
            continue;
        }
        else break;
    }
    border = leftBorder;
    cout<<" Введите точность измерений: "; cin>>epsilon; /// correct entry
    while(fabs(rightBorder-leftBorder)>=epsilon){//!
        iteration++;
        point = leftBorder-(((rightBorder-leftBorder)*(function(leftBorder)))
            /(function(rightBorder)-function(leftBorder)));// !
        cout<<" Point: "<<point;
        if((function(point))*(function(leftBorder))<0)
            rightBorder = point;
        if((function(point))*(function(rightBorder))<0)
            leftBorder = point;
        radical = point;
    }
    double absErr = fabs(test(border)-radical);
    double relErr = (fabs(absErr)/radical)*100;
    cout<<" Корень: "<<radical<<endl;// tmp
    cout<<" Количество итераций: "<<iteration<<endl;// tmp
    cout<<" Абсолютная погрешность: "<<absErr<<endl;// tmp
    cout<<" Относительная погрешность: "<<relErr<<" %"<<endl;//tmp
}
2) файл test.cpp
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
#include "stdafx.h"
#include "description.h"
#include <iostream>
#include <cmath>
#include "description.h"
 
// значения, подсчитанные калькулятором:
double test(double border){
    double x1 = pow(35,0.5) - 5;
    double x2 = -pow(35,0.5) - 5;
    if(border>x2) return x1;
    if(border<x2) return x2;
}
3) файл equation.cpp
C++
1
2
3
4
5
6
7
#include "stdafx.h"
#include "description.h"
#include <cmath>
 
double function(double x){
    return (x*x + 10*x - 10);
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
03.07.2013, 17:24
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Метод хорд в решении простецкой параболы (C++):

Мой код - метод бисекции, метод секущих (метод хорд) - C++
Всем привет!!! Изучаем в институте С++. Сделал код, и там, и там одна и та же проблема - при любых вбиваемых значениях программа делает...

Нахождения корней уравнения: метод половинного деления (бисекции) или метод хорд - C++
Разработать программу нахождения корней уравнения f(x) =0 на интервале с точностью e = 0,001 (интервал или подобрать самостоятельно). При...

метод хорд - C++
помогите решить уравнение tg(0.4x+0.4)=x^2 методом хорд

Метод хорд в С++ - C++
Господа, столкнулся с проблемой. Задание следующее: написать программу, которая находит корни уравнений y= ctg(x) + x/4 и...

Метод хорд - C++
Всем привет! В общем, при решении курсовой по сабжу, столкнулся со следующей проблемой. Первое уравнение программа решает правильно, а...

Метод хорд - C++
#include &lt;conio.h&gt; #include &lt;iostream&gt; #include &lt;math.h&gt; #include &lt;iomanip&gt; using namespace std; double f(double x) { ...

0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.07.2013, 17:24
Привет! Вот еще темы с ответами:

Метод хорд - C++
Есть задание:&quot;Методом хорд найти корень уравнения x-3{x}^{3}+12=0 на отрезке . Написал,но значение выводит неправильное,т.к....

МЕтод хорд - C++
Всем привет. Надо сделать задачку (она на картинке в рамке красной) там надо применить метод хорд... Если кому не сложно, помогите...

Метод Хорд - C++
Объясните пожалуйста как сделать задание. Программа нахождения корня нелинейного уравнения f1(x) = f2(x)? где xn&lt;=x&lt;=xk. Результаты в...

метод хорд - C++
Решить уравнение методом хорд {e}^{x}-x-20=0


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

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

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