Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/8: Рейтинг темы: голосов - 8, средняя оценка - 5.00
14 / 14 / 1
Регистрация: 17.08.2015
Сообщений: 460

Метод хорд (не могу найти ошибку в программе)

02.09.2015, 19:20. Показов 1589. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте,

вот написал программу, которая вычисляет корни ур-я методом хорд. Уравнение вида x^3-0.2*x^2-0.2*x-1.2=0
Интервал (1;1.5)

Код программы, алгоритм, не могу понять, почему постоянно выводит -1.#IND (вроде как на нуль нигде не делю)

Никак не могу понять, в чем косяк..

C++ (Qt)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <iostream>
#include <cmath>
using namespace std;
 
double f(double x)
{
    return  x*x*x-0.2*x*x-0.2*x-1.2; //Здесь вводим ту функцию, которую будем эксплуатировать
}
 
int main()
{
    double a,b,eps,X,x0;
       cout<<"Enter a= "<<endl;cin>>a;     //ввожу и считываю 1
       cout<<"Enter b= "<<endl;cin>>b;     //ввожу и считываю 1.5
       cout<<"Enter eps= "<<endl;cin>>eps; //нужная точность
       x0=a;
           do{
           //так ввели данные, что конец b - неподвижен
           X=x0-(f(x0*(b-x0))/(f(b)-f(x0)));
           x0=X;
       }while(abs(x0-X)<eps);
        cout<<endl<<"Solution is"<<x0;
}
Миниатюры
Метод хорд (не могу найти ошибку в программе)  
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
02.09.2015, 19:20
Ответы с готовыми решениями:

Не могу найти ошибку в программе
Не могу найти ошибку в программе #include &quot;stdafx.h&quot; #include &lt;iostream.h&gt; #include &lt;math.h&gt; #include &lt;fstream.h&gt; ...

Не могу найти ошибку в программе
Разложение числа на сумму двух квадратов &quot;for(a=o;a&lt;=floor(sqrt(W));x++); for(b=0;b&lt;=floor(sqrt(w));y++); if(a*a+b*b==W) ...

Не могу найти ошибку в программе
Даны действительные числа х1, у1, х2, у2, …,х10, у10. Найти периметр десятиугольника, вершины которого имеют соответственно координаты (х1,...

4
Модератор
Эксперт С++
 Аватар для zss
13773 / 10966 / 6491
Регистрация: 18.12.2011
Сообщений: 29,244
02.09.2015, 19:26
Цитата Сообщение от Blitzor DDD Посмотреть сообщение
X=x0-(f(x0*(b-x0))/(f(b)-f(x0)));
C++
1
X=x0-f(x0)*(b-x0)/(f(b)-f(x0));
1
14 / 14 / 1
Регистрация: 17.08.2015
Сообщений: 460
02.09.2015, 19:32  [ТС]
Да, лох я конечно.
Спасибо, но теперь вообще ничего не выводит, я поменял цикл, сделал чуть понятнее вроде бы

C++ (Qt)
1
2
3
4
5
6
7
8
9
 for(;;){
           //так ввели данные, что конец b - неподвижен
          // X=x0-(f(x0*(b-x0))/(f(b)-f(x0)));
           X=x0-f(x0)*(b-x0)/(f(b)-f(x0));
 
           x0=X;
           cout<<endl<<x0;
           if(abs(x0-X)<=eps) break;
          }
но теперь выводит результат неправильный. Выводит x=1.148
А результат должен быть х=1.2

Может быть, в алгоритме ошибка?
0
Модератор
Эксперт С++
 Аватар для zss
13773 / 10966 / 6491
Регистрация: 18.12.2011
Сообщений: 29,244
02.09.2015, 19:44
Лучший ответ Сообщение было отмечено Blitzor DDD как решение

Решение

Цитата Сообщение от Blitzor DDD Посмотреть сообщение
x0=X; // Тут x0 стало равно X
cout<<endl<<x0;
if(abs(x0-X)<=eps) // а тут проверяем, правда ли, что приравняли x0 к X
поменяйте 4 и 6 строки местами
0
14 / 14 / 1
Регистрация: 17.08.2015
Сообщений: 460
02.09.2015, 19:48  [ТС]
Благодарю Вас!
Впредь постараюсь внимательнее анализировать свой код
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.09.2015, 19:48
Помогаю со студенческими работами здесь

Не могу найти ошибку в программе
Прога рабочая, но если вводишь х = 0 и у= 0 то она зацикливается на &quot;Ошибка! Начните заново.&quot; и не работает правильно. Хотя должна....

Не могу найти ошибку в программе
#include &lt;iostream&gt; #include &lt;fstream&gt; #include &lt;cctype&gt; #define is_delim(c) (std::isspace((c)) || std::ispunct((c))) using...

Не могу найти ошибку в программе
# include &lt;iostream&gt; #include &lt;string&gt; #include &lt;math.h&gt; void main() { string str; char hex={'0', '1', '2', '3', '4',...

Не могу найти ошибку в программе
Здравствуйте! Не могу понять, как полностью отладить программу. Определенное понимание о характере ошибке есть( ниже прложил ее название),...

не могу ошибку найти в программе
#include &lt;iostream&gt; #include &lt;ctime&gt; #include &lt;cstdlib&gt; #include &lt;iomanip&gt; #include &lt;cmath&gt; double average(int ** matrix, int...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru