求一元二次方的根(虚根求法)

入门级求根

#include<iostream>
#include<cmath>
using namespace std;
int main()
{
	float a,b,c,d;
	cout<<"输入三个系数";
	cin>>a>>b>>c;
	cout<<"a="<<a<<'\t'<<"b="<<b<<'\t'<<"c="<<c<<endl;
	d=b*b-4*a*c;
	if (d<0)
	{
	cout<<"该方程无实根!"<<endl;
	}
	else{
	d=sqrt(d);
	if(d)
	{
	cout<<"该方程有两个不等的实数根"<<endl;
	cout<<"x1="<<(-b+d)/2/a<<'\t'<<"x2="<<(-b-d)/2/a<<endl;
	}
	else{cout<<"该方程有两个相等的根"<<endl;
		 cout<<"x1=x2="<<(-b+d)/2/a<<endl;}
	}
	return 0;
}

该方法无法求出虚根(无法求出的d<0时的虚根);下面用调用函数的方法求一元二次方程的根

先补充一个知识点:

例题如下:设置精度的操作

图片来源:C语言程序设计教程(第三版)课后习题4.9 (C++代码)-Dotcpp编程社区

#include<iostream>
#include<cmath>
#include <iomanip>
using namespace std;
void  fun1(float a, float b, float d)          //d>0时,直接带公式
{
	float x1,x2;
	d = sqrt(d);
	x1 = (-b + d) / 2 / a;
	x2 = (-b - d) / 2 / a;
	cout << "x1= "<<x1 <<'\t' << "x2="<<x2;
}
void fun2(float a, float b)             //d=0时,直接带公式
{
	float x;
	x = -b / 2 / a;
	cout<<"x1=x2="<< x;
}
void fun3(float a, float b,float d)       //d<0时,用虚数表示方程的根
{
	d = -d;
	d = sqrt(d);
	d = d / 2 / a;
	float x = -b / 2 / a;
	cout << fixed << setprecision(3) << "x1=" << x << "+" << d << "i" << '\t' << "x2=" << x << "-" << d << "i";
}
int main()
{
	float a, b,c,d;
	cin >> a >> b>>c;
	d = b * b - 4*a*c;
	if (d > 0)
		fun1(a, b, d);
	else if (d == 0)         //易错写成=
		fun2(a, b);
	else
		fun3(a, b, d);
   return 0;
}

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在Java中,可以使用一元二次方程的求根公式解方程的一元二次方程的一般形式为:ax^2 + bx + c = 0,其中a、b、c为系数。 要考虑虚根,需要判断方程的判别式D的值。判别式D的计算公式为:D = b^2 - 4ac。 如果D大于0,则方程有两个实; 如果D等于0,则方程有一个实; 如果D小于0,则方程没有实,但有两个虚根。 下面是Java代码示例,用于一元二次方程的(考虑虚根): ```java import java.util.Scanner; public class QuadraticEquation { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); System.out.println("请输入一元二次方程的系数:"); System.out.print("a = "); double a = scanner.nextDouble(); System.out.print("b = "); double b = scanner.nextDouble(); System.out.print("c = "); double c = scanner.nextDouble(); double discriminant = b * b - 4 * a * c; if (discriminant > 0) { double root1 = (-b + Math.sqrt(discriminant)) / (2 * a); double root2 = (-b - Math.sqrt(discriminant)) / (2 * a); System.out.println("方程有两个实:"); System.out.println("x1 = " + root1); System.out.println("x2 = " + root2); } else if (discriminant == 0) { double root = -b / (2 * a); System.out.println("方程有一个实:"); System.out.println("x = " + root); } else { double realPart = -b / (2 * a); double imaginaryPart = Math.sqrt(-discriminant) / (2 * a); System.out.println("方程没有实,有两个虚根:"); System.out.println("x1 = " + realPart + " + " + imaginaryPart + "i"); System.out.println("x2 = " + realPart + " - " + imaginaryPart + "i"); } } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SweetCinderella

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值