| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2182 人关注过本帖
标题:用二分法求根:陷入了死循环(已解决)
取消只看楼主 加入收藏
yqiong
Rank: 1
等 级:新手上路
帖 子:315
专家分:0
注 册:2007-7-4
结帖率:83.33%
收藏
 问题点数:0 回复次数:4 
用二分法求根:陷入了死循环(已解决)
用二分法求根:陷入了死循环
#include<iostream>
using namespace std;
int main()
{
    double fabs(double  ,double);
    double f(double );
       double x2,x1,x;
    do{
             cout<<"请输入x1和x2的值:";
            cin>>x1>>x2;
            cout<<"x1="<<x1<<"  x2="<<x2;
    }while(f(x1)*f(x2)>0);

    do{
        x=(x1+x2)/2;
        if(f(x)*f(x1)>0) x2=x;
        else x1=x;
    }while(fabs(f(x),0)>=1e-5);

    cout<<"结果为:"<<x;
    return 0;
}

double f(double x)
{      return(((x+-5)*x+16)*x+-80);}

double fabs(double a,double b)
{    return (a-b>0?a-b:b-a);}

[[it] 本帖最后由 yqiong 于 2008-3-21 15:41 编辑 [/it]]
搜索更多相关主题的帖子: double 二分法 cout fabs 
2008-03-20 17:18
yqiong
Rank: 1
等 级:新手上路
帖 子:315
专家分:0
注 册:2007-7-4
收藏
得分:0 
[bo]以下是引用 [un]PcrazyC[/un] 在 2008-3-20 18:09 的发言:[/bo]

二分法有一个严格的限制就是要在一个单调区间上,如果你输入的数不在一个单调区间就会出现死循环,你这个题中明显有一个答案是5,所以我输入4,6就行了,其它的,自己再找 ...


答案是5,但我输入2 6时怎么也陷入死循环了呀?
2008-03-20 22:50
yqiong
Rank: 1
等 级:新手上路
帖 子:315
专家分:0
注 册:2007-7-4
收藏
得分:0 
do{
       cout<<"请输入x1和x2的值:";
       cin>>x1>>x2;
       cout<<"x1="<<x1<<"  x2="<<x2;
    }while(f(x1)>0&&f(x2)>0)//不明白。只有当异号时才能确保在x1和x2间有一值使函数值为0呀!
    do{
        x=(x1+x2)/2;
        if(f(x)>0&&f(x1)>0)  x2=x;
        else x1=x;
    }while(fabs(f(x),0)>=1e-5);

运行时输入2 6确实能正确输出答案5,但改输入3 6又出问题了呢!
2008-03-21 15:33
yqiong
Rank: 1
等 级:新手上路
帖 子:315
专家分:0
注 册:2007-7-4
收藏
得分:0 
do{
        x=(x1+x2)/2;
        if(f(x)*f(x1)>0) x1=x;     
       else x2=x;  //找到原因了,就错在这!
  }while(fabs(f(x),0)>=1e-5);
2008-03-21 15:40
yqiong
Rank: 1
等 级:新手上路
帖 子:315
专家分:0
注 册:2007-7-4
收藏
得分:0 
没区别吧,放在里面的是旧版的。两种形式C都支持
2008-03-24 12:10
快速回复:用二分法求根:陷入了死循环(已解决)
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.031070 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved