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

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

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

Метод хорд - C++

20.12.2013, 00:07. Просмотров 564. Ответов 2
Метки нет (Все метки)

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
#include <conio.h>
#include <iostream>
#include <math.h>
#include <iomanip>
using namespace std;
 
double f(double x) 
{
   return 2*pow(x,3)-pow(x,2)-0,46;
}
double findRoot(double (*f)(double), double a=0.5, double b=1., double eps=1e-6) 
{
   double t;
   while (fabs(b-a)>=eps) 
   { 
      t = a+(f(b)*(b-a))/(f(b)-f(a));
      if (f(a)*f(t)<0) 
      {
          b=t;
          } 
      else 
          if (f(t)*f(b)<0) 
          {
              a=t;
              } 
          else 
              return t;
   }
   return t;
}
 
int main() 
{
   double t = findRoot(f);
   cout << "x=" << t << endl;
   system("pause");
}
Как-то так.. выводит "1.#INF"
Вопросы:
как выводить значение точнее?
как убрать #INF?
как сделать, чтобы программа функционировала правильно?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.12.2013, 00:07
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Метод хорд (C++):

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

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

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

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

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

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

2
nomyac
2 / 9 / 1
Регистрация: 12.10.2013
Сообщений: 43
20.12.2013, 00:32 #2
Заработает, просто немного магии)
1) Переделай функцию на такую
C++
1
2
3
4
5
6
double f(double x) 
{
    double l;
    l=2*pow(x,3)-pow(x,2)-0,46;
    return l;
}
2. В строке
C++
1
double findRoot(double (*f)(double), double a=0.5, double b=1., double eps=1e-6)
не дописано значение, после точки.
0
G_
0 / 0 / 0
Регистрация: 23.11.2013
Сообщений: 17
21.12.2013, 19:33  [ТС] #3
nomyac, вы про эту штуку:
C++
1
double b=1.
?
Точка после числа случайно не обозначает, что оно (число) отностися к типу float?
Предлагаете в значении написать 1.0?

Добавлено через 5 минут
P.S. онлайн калькулятор выдаёт x = 0.83211964, а программа выдаёт 1
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
21.12.2013, 19:33
Привет! Вот еще темы с ответами:

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

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

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

МЕТОД ХОРД И КАСАТЕЛЬНЫХ - C++
Господа программисты, очень нужна ваша помощь. Нужно написать программу на C++, в ней решить любое уравнение от балды методом хорд и...


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

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

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