C语言编程:求1元2次方程的根

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C语言编程:求1元2次方程的根相关的知识,希望对你有一定的参考价值。

#include <stdio.h>

#include <math.h>

int main()

double a,b,c;                                /*定义系数变量*/

double x1,x2,p;                              /*定义根变量和表达式的变量值*/

printf("请输入a,b,c:");                      /*提示用户输入三个系数*/

scanf("%lf%lf%lf",&a,&b,&c);                 /*接收用户输入的系数*/

printf("\\n");                               /*输出回行*/

p=b*b-4*a*c;                            /*给表达式赋值*/

x1=(-b+sqrt(p))/(2*a);                           /*根1的值*/

x2=(-b-sqrt(p))/(2*a);                           /*跟2的值*/

printf("x1=%f,x2=%f\\n",x1,x2);                   /*输出两个根的值*/

拓展资料

在实际的求法中,一般还需要判断有无实根,这是可以通过p的值来判断

参考技术A #include<stdio.h>
#include<math.h>
main()

double a,b,c,x1,x2,temp,temp1;
printf("请输入参数a的值为:\n");
scanf("%lf",&a);
printf("请输入参数b的值为:\n");
scanf("%lf",&b);
printf("请输入参数c的值为:\n");
scanf("%lf",&c);
temp=b*b-4*a*c;
temp1=sqrt(temp);
if(temp<0)
printf("该函数没有实解!")
else if(temp==0)
x1=x2=(b*b-temp1)/2*a
printf("该函数有两个相等的实根!分别为:x1=x2=%lf",x1);
else if(temp>0)
x1=(b*b-temp1)/2*a;x2=(b*b+temp1);
printf("该函数有两个不同的实根,分别为:x1=%lf \n x2=%lf \n",x1,x2);


//你试试看,当场发挥,有点不自信。。。本回答被提问者和网友采纳
参考技术B ax*x+bx+c=0
#include<stdio.h>
#include<math.h>
int main()

double x1,x2;
double a,b,c,dert;
scanf("%lf%lf%lf",&a,&b,&c);
dert=sqrt(b*b-4*a*c);
x1=(-b+dert)/(2*a);
x2=(-b-dert)/(2*a);
printf("%lf %lf\n",x1,x2);
reutrn 0;

用C语言编写求一元二次方程根的程序

条件要判断的充分

用C语言编写求一元二次方程根的程序,条件判断的充分,步骤如下:

void main()

float a,b,c,delta;
scanf("%f%f%f",&a,&b,&c);
if(a!=0)

delta=b*b-4*a*c;
if(delta==0)
printf("x1=x2=%7.2f",-b/(2*a));
else if(delta>0)

printf("x1=%7.2f",(-b+sqrt(delta))/(2*a));
printf("x2=%7.2f",(-b-sqrt(delta))/(2*a));

else

printf("x1=%7.2f+i%7.2f",-b/(2*a),sqrt(-delta)/(2*a));
printf("x2=%7.2f-i%7.2f",-b/(2*a),sqrt(-delta)/(2*a));


else if(b!=0)
printf("x=%7.2f",-c/b);
else if(c==0)
printf("0=0,x为任意解
");
else
printf("%f=0,error!",c);

参考技术A #include <stdio.h>
#include <math.h>
int main()

double a,b,c,disc,x1,x2,realpart,imagpart;
scanf("%lf%lf%lf",&a,&b,&c);
printf("The equation");
if (fabs(a)<=1e-6)
printf(" is not a quadratic\\n");
else

disc=b*b-4*a*c;
if (fabs(disc)<=1e-6)
printf(" has two equal roots:%8.4f\\n",-b/(2*a));
else
if (disc>0)

x1=(-b+sqrt(disc))/(2*a);
x2=(-b-sqrt(disc))/(2*a);
printf(" has distinct real roots:%8.4f and %8.4f\\n",x1,x2);

else

realpart=-b/(2*a);
imagpart=sqrt(-disc)/(2*a);
printf(" has complex roots:\\n");
printf("%8.4f+%8.4fi\\n",realpart,imagpart);
printf("%8.4f-%8.4fi\\n",realpart,imagpart);


return 0;

参考技术B #include "stdio.h"
#include "math.h"
double x1,x2,p;

float file1(float a,float b)

x1=(-b+sqrt(p))/2*a;
x2=(-b-sqrt(p))/2*a;
return 0;


float file2(float a,float b)

x1=x2=(-b+sqrt(p))/2*a;
return 0;


void main()

float a,b,c;
scanf("%f%f%f",&a,&b,&c);
p=b*b-4*a*c;
printf("方程是:%.3f*x*x+%.3f*x+%.3f=0\n",a,b,c);
if(p>0)

file1(a,b);
printf("X1=%f\tX2=%f\n",x1,x2);

else if(p==0)

file2(a,b);
printf("X1=%f\tX2=%f\n",x1,x2);

else printf("方程无解");


运行正确 输入: 2 3.7 1.2
输出 X1=-1.677625 X2=-5.722375
参考技术C #include<stdio.h>
#include<math.h>
int main(void)

float a,b,c;
double x1,x2;
double delta;
printf("输入a,b,c数值:\n");
scanf("%f%f%f",&a,&b,&c);

if (a!=0)
delta=pow(b,2)-4*a*c;
if(delta==0)

printf("x1=x2=%.2f\n",-b/(2*a));

if(delta>0)

x1=(-b+sqrt(delta))/(2*a);
x2=(-b-sqrt(delta))/(2*a);
printf("x1=%.2f x2=%.2f\n",x1,x2);

if(delta<0)

printf("无解!\n");


return 0 ;

以上是关于C语言编程:求1元2次方程的根的主要内容,如果未能解决你的问题,请参考以下文章

如何用C语言求一元二次方程的根?

c语言求一元二次方程的根

求一元二次方程的根c语言

c语言编写一元2次方程。

C语言 求一元二次方程的根 openjudge

用C语言编写一程序求解一元二次方程的根。