24小时热门版块排行榜    

查看: 1941  |  回复: 5
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

xingwuyan

新虫 (初入文坛)

[求助] 求高手帮我编一个一元三次方程求解的小程序!重谢哦!

求哪位程序高手,能够帮我编写一个C语言程序解一元三次方程!!重谢!
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

emanlee

木虫 (小有名气)

【答案】应助回帖


感谢参与,应助指数 +1
dubo: 金币+1, 欢迎讨论 2012-04-06 19:01:20
#include
#include
int a,b,c,d;
int count=0;
double x[3]={-200,-200,-200};
void fun(double x1,double x2)
{
     double x3,y1,y2,y3;
         int i=0;
         
         while (x2-x1>10e-6)
         {
                 x3=(x1+x2)/2;
                 y1=a*x1*x1*x1+b*x1*x1+c*x1+d;
        y2=a*x2*x2*x2+b*x2*x2+c*x2+d;
                y1=a*x1*x1*x1+b*x1*x1+c*x1+d;
        y3=a*x3*x3*x3+b*x3*x3+c*x3+d;
                if (y1==0)
                {
                        for (i=0;i<3;i++)
                        {
                                if (x==x1)
                                {
                                        return;
                                }
                                if (x==-200)
                                {
                                        count++;
                                        x=x1;
                                        return;
                                }
                               
                        }
                }
                else if (y2==0)
                {
                        for (i=0;i<3;i++)
                        {
                                if (x==x2)
                                {
                                        return;
                                }
                                if (x==-200)
                                {
                                        count++;
                                        x=x2;
                                        return;
                                }
                        }
                }
                else if (y3==0)
                {
                        for (i=0;i<3;i++)
                        {
                                if (x==x3)
                                {
                                        return;
                                }
                                if (x==-200)
                                {
                                        count++;
                                        x=x3;
                                        return;
                                }
                        }
                }
                else if (y1*y3<0)
                {
                        x2=x3;
                }
                else
                {
                        x1=x3;
                }
         }
         for (i=0;i<3;i++)
         {
                 if (x==x1)
                 {
                         return;
                 }
                 if (x==-200)
                 {
                         count++;
                         x=x1;
                         return;
                }
         }

}
int main()
{
       
        double x1,x2,y1,y2,x3,x4;
        scanf("%d,%d,%d,%d",&a,&b,&c,&d);
        for (x1=-100,x2=x1+1;x1<100;x1+=1,x2+=1)
        {
                y1=a*x1*x1*x1+b*x1*x1+c*x1+d;
        y2=a*x2*x2*x2+b*x2*x2+c*x2+d;
        x3=x1;
                x4=x2;
                if (y1*y2<=0)
                {
                        fun(x3,x4);
                                if (count==3)
                                {
                                        break;
                                }
                }
        }
        for(int i=0;i<3;i++)
        {
                printf("%.2lf ",x);
        }
        printf("\n";
        return 0;
}
6楼2012-04-03 08:42:01
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 6 个回答

锐利的碎片

木虫 (正式写手)

star watcher

【答案】应助回帖


jjdg(金币+1): 感谢参与 2011-10-27 13:04:49
1。给出方程
2.一元3次方程有解析解的。
2楼2011-10-27 12:52:11
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

xingwuyan

新虫 (初入文坛)

引用回帖:
2楼: Originally posted by 锐利的碎片 at 2011-10-27 12:52:11:
1。给出方程
2.一元3次方程有解析解的。

灰常感谢啊!就是四个系数a,b,c,d。a,b,c,d是可以求的,并且我知道有两个是虚根,只有一个是实根,我要的是那个实根,再次3Q
3楼2011-10-27 15:26:40
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

noryark

木虫 (正式写手)

jjdg: lz不是写了吗?20个金币 2011-10-28 00:48:42
这个可以编写 怎么重谢? 不会是虚拟的金币吧
...
4楼2011-10-27 18:46:46
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
信息提示
请填处理意见