| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 517 人关注过本帖
标题:帮忙看下程序,实在检查不出错误……
只看楼主 加入收藏
笨小孩1
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2010-12-10
结帖率:100%
收藏
已结贴  问题点数:10 回复次数:6 
帮忙看下程序,实在检查不出错误……
二分法求两方程的根
检查语法没错
我新来的,多多照顾


#include<stdio.h>
#include<math.h>
float root (float x1,float x2,double (*f)(double))
{
    float x=0;
    do
    {    x=(x1+x2)/2.0;
        if (f(x)*f(x2)>=0)
            x1=x;
        else x2=x;
        
    }
    while (fabs(f(x))>=1e-5);

    return x;
}
double f1 (double x)
{
    return sin(2*x+1);
}
double f2 (double x)
{
    return x*x*x-5*x*x+16*x-80;
}
void main ()
{
    double y1,y2;
    y1=root (-1,3,f1);
    y2=root (2,6,f2);
    printf("%.2f\n",y1);
    printf("%.2f\n",y2);
}
搜索更多相关主题的帖子: 检查 
2010-12-10 17:34
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:0 
死循环了..................

                                         
===========深入<----------------->浅出============
2010-12-10 21:51
燕强
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:78
专家分:188
注 册:2010-8-11
收藏
得分:0 
以下是引用笨小孩1在2010-12-10 17:34:21的发言:

二分法求两方程的根
检查语法没错
我新来的,多多照顾


#include
#include
float root (float x1,float x2,double (*f)(double))
{
    float x=0;
    do
    {    x=(x1+x2)/2.0;
        if (f(x)*f(x2)>=0)
            x1=x;
        else x2=x;
        
    }
    while (fabs(f(x))>=1e-5);     //看看这里是不是有错误啊..你用fabs()取绝对值,其值当然大于等于1e-5啊

    return x;
}
double f1 (double x)
{
    return sin(2*x+1);
}
double f2 (double x)
{
    return x*x*x-5*x*x+16*x-80;
}
void main ()
{
    double y1,y2;
    y1=root (-1,3,f1);
    y2=root (2,6,f2);
    printf("%.2f\n",y1);
    printf("%.2f\n",y2);
}


导致进入死循环了.
2010-12-11 12:53
笨小孩1
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2010-12-10
收藏
得分:0 
是死循环,不过这里好像不是这里的问题啊
2010-12-12 17:46
mengcong3959
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:41
专家分:113
注 册:2010-12-6
收藏
得分:0 
y1=root (-1,3,f1);
 y2=root (2,6,f2);
 既然f1,f2都是函数,,为什么函数里面没有实参啊?
2010-12-12 21:52
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:10 
程序代码:
#include<stdio.h>
#include<math.h>
float f2 (float x)
{
    return x*x*x-5*x*x+16*x-80;// 求出函数值 也就是y坐标
}
float xpoint(float x1,float x2)
{
return (x1*f2(x2)-x2*f2(x1))/(f2(x2)-f2(x1));// 求出直线与x轴的交点
}
float root (float x1,float x2,float (*f)(float))
{
    float x=0,y1=0,y=0;
y1=f(x1); 
    do
    {
x=xpoint(x1,x2);//求出直线与x轴交点
y=f(x);
        if (y*y1>0)//如果在同一侧
{
            x1=x;
y1=y;
}
else//不在同一侧
x2=x;
    }
    while ((float)fabs(y)>=0.1);
    return x;
}
/*float f1 (float x)
{
    return sin(2*x+1);
} */
void main ()
{
    float y1,y2;
    //y1=root (-1,3,f1);
    y2=root (2,6,f2);
    //printf("%.2f\n",y1);
    printf("%.2f\n",y2);
}
第一个  3次方程的我弄好了   剩下的那个请楼主自己动手吧

                                         
===========深入<----------------->浅出============
2010-12-12 21:56
笨小孩1
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2010-12-10
收藏
得分:0 
#include<stdio.h>
#include<math.h>
float root (float x1,float x2,double (*f)(double))
{
    float x=0;
    do
    {    x=(x1+x2)/2.0;
        if (f(x)*f(x2)>=0)
            x1=x;    //是这里有问题,应该是x2=x;   else x1=x;
        else x2=x;
        
    }
    while (fabs(f(x))>=1e-5);

    return x;
}
……
……

终于找出错误了,多谢各位帮忙
2010-12-14 22:37
快速回复:帮忙看下程序,实在检查不出错误……
数据加载中...
 
   



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

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