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

Программа останавливает свою работу, когда начинает выполнятся функция. Метод хорд - C++

Восстановить пароль Регистрация
 
kikotus
0 / 0 / 0
Регистрация: 25.11.2014
Сообщений: 3
25.11.2014, 12:32     Программа останавливает свою работу, когда начинает выполнятся функция. Метод хорд #1
Писал программу для нахождения приближенных корней методом хорд, но программа работает нормально только до вызова функции Hord. Ввожу промежуток на котором есть корень, затем выбираю в меню программы "Метод Хорд", но консоль зависает на вызове этой функции.Вод код, если что корень находится на промежутке 1,2 и eps 0.01:

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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
#include<iostream>
#include<conio.h>
#include<cmath>
using namespace std;
double fx(double x0){//сама функция
    double y;
    y=pow(x0,3)-0.2*pow(x0,2)+0.4*x0-1.4;
    return y;
}
double ddx(double dx){//вторая производная
    double dy;
    dy=6*dx-0.4;
    return dy;
}
double hord(double a0,double b0,double eps0){//метод хорд
    double xn,xs;
    if((fx(b0)*ddx(b0))>0){
        xn=a0;
        do{
        xs=xn-((fx(xn)*(b0-xn))/(fx(b0)-fx(xn)));
        if(fx(xs)==0){
            cout<<"Корень уравнения x= "<<xs<<endl<<"Функция f(x)= "<<fx(xn)<<endl;
        return -1;}
        else{
            xn=xs;}
        }while(fabs(xs-xn)<eps0);
        cout<<"Корень уравнения x= "<<xs<<endl<<"Функция f(x)= "<<fx(xn)<<endl;
 
    }
        else{
        if((fx(b0)*ddx(b0))<0){
            xn=b0;
        do{
        xs=xn-((fx(xn)*(xn-a0))/(fx(xn)-fx(a0)));
        if(fx(xs)==0){
            cout<<"Корень уравнения x= "<<xs<<endl<<"Функция f(x)= "<<fx(xn)<<endl;
        return -1;}
        else{
            xn=xs;}
        }while(fabs(xs-xn)<eps0);
        cout<<"Корень уравнения x= "<<xs<<endl<<"Функция f(x)= "<<fx(xn)<<endl;}
        }
        return 0;}
int main()
{
    double a,b,eps;
    int option(0);
    char charoption;
    setlocale(0,"Russian");
    do{
    system("cls");
    cout<<"\t\t***Программа для нахождения приближенных корней***\n\t\t\tметодом Хорд и Секущих\n\n";
    cout<<"Введите первый край а: ";
    cin>>a;
    cout<<"Введите второй край b: ";
    cin>>b;
    cout<<"Введите eps: ";
    cin>>eps;
    if(fx(a)*fx(b)>0){
        cout<<"Введенный промежуток не подходят!";
        _getch();
        return -1;}
    cout<<"\nВыберите желаемое действие:\n1-для нахождения корней методом Хорд\n2-для нахождения корней методом Секущих";
    cout<<"\n3-для нахождения корней сразу двумя методами\n0-выход из программы \n";
    cin>>option;
    system("cls");
    switch(option){
        case 1:{
            cout<<"Метод Хорд:\n";
            hord(a,b,eps);
            cout<<"Хотите выйти в главное меню?(y/n)";
            cin>>charoption;
            break;
               }
        case 2: {
            cout<<"Метод Секущих\n";
 
            cout<<"Хотите выйти в главное меню?(y/n)";
            cin>>charoption;
            break;
                }
        case 3: {
            cout<<"Нахождение двумя методами сразу:\n";
 
            cout<<"Хотите выйти в главное меню?(y/n)";
            cin>>charoption;
            break;
                }
        case 0:{
            return -1;
               }
        }
    }while(charoption=='y');
    _getch();
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.11.2014, 12:32     Программа останавливает свою работу, когда начинает выполнятся функция. Метод хорд
Посмотрите здесь:

метод хорд C++
C++ Программа завершает свою работу и закрытаеться
C++ МЕтод хорд
Метод хорд C++
C++ Метод хорд
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
nmcf
4307 / 3728 / 1257
Регистрация: 14.04.2014
Сообщений: 14,610
25.11.2014, 12:39     Программа останавливает свою работу, когда начинает выполнятся функция. Метод хорд #2
Используй отладчик. Точку останова на начало функции hord() и смотри, что происходит.
zss
Модератор
Эксперт С++
 Аватар для zss
5950 / 5555 / 1786
Регистрация: 18.12.2011
Сообщений: 14,196
Завершенные тесты: 1
25.11.2014, 12:43     Программа останавливает свою работу, когда начинает выполнятся функция. Метод хорд #3
Метод хорд не сближает точки xs и xn.
Надо смотреть разницу между текущим и предыдущим значениями xs
kikotus
0 / 0 / 0
Регистрация: 25.11.2014
Сообщений: 3
25.11.2014, 13:38  [ТС]     Программа останавливает свою работу, когда начинает выполнятся функция. Метод хорд #4
спасибо. проблема была в неверном присваивании. только теперь возник вопрос - как модуль числа возвращать с большим количеством цифр после запятой? функция abs или fabs возвращает только 4 цифры.
zss
Модератор
Эксперт С++
 Аватар для zss
5950 / 5555 / 1786
Регистрация: 18.12.2011
Сообщений: 14,196
Завершенные тесты: 1
25.11.2014, 13:49     Программа останавливает свою работу, когда начинает выполнятся функция. Метод хорд #5
Неправда.
fabs возвращает double (17 значащих цифр).
Т.е. если число порядка единицы, то 17 цифр после запятой.
kikotus
0 / 0 / 0
Регистрация: 25.11.2014
Сообщений: 3
25.11.2014, 14:45  [ТС]     Программа останавливает свою работу, когда начинает выполнятся функция. Метод хорд #6
когда программа доходит до этого момента "}while(fabs(xs-xn1)<eps0);" выбивает такую ошибку
Программа останавливает свою работу, когда начинает выполнятся функция. Метод хорд
Yandex
Объявления
25.11.2014, 14:45     Программа останавливает свою работу, когда начинает выполнятся функция. Метод хорд
Ответ Создать тему
Опции темы

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