24小时热门版块排行榜    

Znn3bq.jpeg
查看: 2058  |  回复: 5

xingwuyan

新虫 (初入文坛)

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

求哪位程序高手,能够帮我编写一个C语言程序解一元三次方程!!重谢!
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

锐利的碎片

木虫 (正式写手)

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的回帖

capital_j

木虫 (小有名气)

【答案】应助回帖


感谢参与,应助指数 +1
jjdg: 金币+1, 感谢参与 2012-04-02 03:38:34
#include
#include
using namespace std;
int isFloatsEqual(float a,float b,float c=1e-2)
{
    if(fabs(a-b)     else return 0;
}
int func(float a,float b,float c,float d)
{
    if(a==0) return 1;
    float A = b*b-3*a*c;
    float B = b*c-9*a*d;
    float C = c*c-3*b*d;
    float derta = B*B - 4*A*C;
    cout<         <     if(isFloatsEqual(A,B)&&isFloatsEqual(A,0)) {
        cout<<"A =B 公式一:有三个重根\n X1,2,3 = "<<-b/3/a<         return 0;
    }
    if(derta>0){
        float Y1 =A*b+1.5*a*(-B+pow(derta,0.5));
        float Y2 =A*b+1.5*a*(-B-pow(derta,0.5));
        cout<<"Δ>0 公式二:有一个实根和两个共轭虚根\n";
        cout<         cout<<"X1 = "<<(-b-pow(Y1,1.0/3)-pow(Y2,1.0/3))/3/a<         float squ = (-2*b+pow(Y1,1.0/3)+pow(Y2,1.0/3))/6/a;
        float vir = pow(3,0.5)*(pow(Y1,1.0/3)-pow(Y2,1.0/3))/6/a;
        cout<<"X2 = "<         cout<<"X3 = "<         return 0;
    }
    if(isFloatsEqual(derta,0)) {
        if(isFloatsEqual(A,0)) return 1;
        float K = B/A;
        cout<<"Δ=0 公式三:有三实根包括两个重根\n";
        cout<<"X1 = "<<-b/a+K<         cout<<"X2,3 = "<<-K/2<         return 0;
    }
    if(derta<0){
        float T = (2*A*b-3*a*B)/(2*pow(A,1.5));
        float degree = acos(T);
        cout<<"Δ<0 公式四:有三不相等实根\n";
        float squ1 = (-b+pow(A,0.5)*cos(degree/3))/3/a;
        float squ2 = pow(3*A,0.5)*sin(degree/3)/3/a;
        cout<<"X1 = "<<(-b-2*pow(A,0.5)*cos(degree/3))/(3*a)<         cout<<"X2 = "<         cout<<"X3 = "<         return 0;
    }
}
int main()
{
    int a1=1,a2=67.4,a3=1417.92,a4=-9539.712;
    while(a1)
    {
        func(a1,a2,a3,a4);
        cout<<"= = = = = = = = = = = = = = ="<         cin>>a1>>a2>>a3>>a4;
    }
    return 0;
}
利用盛金公式。参见百度百科。但是没有严格的得到学术界的认可。
程序没有经过优化,只是将盛金公式以C++的形式展现出来。
主要就看个思路吧
有些誓言,说了就不起作用了。有的人,见了却没有感觉了了。珍惜现在每一秒,不苛求将来。
5楼2012-04-02 00:10:04
已阅   回复此楼   关注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的回帖
相关版块跳转 我要订阅楼主 xingwuyan 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 本科211 工科085400 280分求调剂 可跨专业 +8 LZH(等待调剂中 2026-04-10 8/400 2026-04-10 10:39 by xujun0624
[考研] 0858求调剂 5+4 Gky09300550, 2026-04-10 5/250 2026-04-10 10:15 by lbsjt
[考研] 一志愿双非085400电子信息344 求调剂,对材料和化学方向也感兴趣 +8 无情的小羊 2026-04-09 9/450 2026-04-10 09:30 by 松花缸1201
[考研] 289 分105500药学专硕求调剂(找B区学校) +5 白云123456789 2026-04-09 7/350 2026-04-09 21:03 by 白云123456789
[考研] 289求调剂 +4 L1ttleTiger 2026-04-04 4/200 2026-04-09 19:53 by xiayizhi
[考研] 266求调剂,一志愿哈工程电子信息,本科获多项国奖和省奖 +4 lumine1 2026-04-06 4/200 2026-04-09 17:38 by vgtyfty
[考研] 求调剂希望还是希望在山河四省附近 +3 快乐的小白鸽 2026-04-05 3/150 2026-04-09 17:36 by wp06
[考研] 调剂 +12 JLLLLLLLLLL 2026-04-03 12/600 2026-04-09 16:14 by angeltong
[考研] 349学科化学045106求调剂,化学类都可以 +8 保好懂懂 2026-04-08 8/400 2026-04-09 14:03 by xulei3024
[考研] 085404,334分,求调剂 +5 sunjie8888 2026-04-08 8/400 2026-04-09 07:26 by sunjie8888
[考研] 334分机械专硕求调剂 +3 蛋花紫菜汤 2026-04-03 3/150 2026-04-07 14:49 by 逍遥cocoa
[考研] 软工学硕299求调剂 +6 useryy 2026-04-07 6/300 2026-04-07 09:50 by vgtyfty
[考研] 308求调剂 +4 maverick^_^ 2026-04-03 4/200 2026-04-05 19:08 by 蓝云思雨
[考研] 一志愿9材料学硕297已过六级求调剂推荐 +11 adaie 2026-04-04 12/600 2026-04-05 19:04 by 蓝云思雨
[考研] 298求调剂 +7 manman511 2026-04-05 7/350 2026-04-05 10:29 by 唐沐儿
[考研] 320求调剂 +3 一样圆 2026-04-04 3/150 2026-04-04 22:29 by 啵啵啵0119
[考研] 283分求调剂 +7 小聂爱学习 2026-04-03 7/350 2026-04-04 21:51 by hemengdong
[考研] 272求调剂 +4 松柏常青5 2026-04-03 4/200 2026-04-04 17:03 by babysonlkd
[考研] 一志愿中国石油大学化学工程323分求调剂 +4 化工专硕323分 2026-04-03 6/300 2026-04-03 22:12 by dongzh2009
[考研] 求材料调剂 一志愿南昌大学 328分 +5 yyy..... 2026-04-03 5/250 2026-04-03 13:46 by 百灵童888
信息提示
请填处理意见