C语言程序-求一元二次方程ax²+bx+c=0的实根解(设a≠0)

一、问题描述

求一元二次方程ax²+bx+c=0的实根解(设a≠0

二、算法设计

算法的具体步骤如下:

① 输入abc

② 计算判别式d=b*b-4*a*c

③ 若d≥0,则求实根x₁,x₂,并输出,否则输出无实根信息;

④ 结束。

三、实现程序

代码如下:

#include<stdio.h> 
#include "math.h" 
void main(){
	float a,b,c; //定义存储方程式系数的变量 
 	float x1,x2,d; //x1、x2储方程根,d存储判别式的值 
 	printf("请输入a,b,c的值: ");
 	scanf("%f%f%f",&a,&b,&c); //输入方程式的系数值 
 	d=b*b-4*a*c; //计算判别式的值 
 	if(d>=0.0){ //当方程有实根时,求方程的两个实根 
	 	x1=(-b+sqrt(d))/(2*a); //计算x1
   		x2=(-b-sqrt(d))/(2*a); //计算x2 
   		printf("x1=%f,x2=%f",x1,x2); //输出x1、x2 
	}else{ //当方程无实根时,输出无实根信息 
		printf("方程无实根");
	}
}

实现效果:

C语言中,我们可以使用数学库函数`sqrt()`来计算平方,并结合公式来一元二次方程。这里是一个简单的程序示例: ```c #include <stdio.h> #include <math.h> // 包含数学运算头文件 // 定义函数一元二次方程的两个 void quadraticRoots(double a, double b, double c) { double delta = b * b - 4 * a * c; // 计算判别式 if (delta > 0) { // 实数 double root1 = (-b + sqrt(delta)) / (2 * a); double root2 = (-b - sqrt(delta)) / (2 * a); printf("一元二次方程有两个实根:%.2lf 和 %.2lf\n", root1, root2); } else if (delta == 0) { // 双重 double root = -b / (2 * a); printf("一元二次方程有一个实根:%.2lf\n", root); } else { // 复数 double realPart = -b / (2 * a); double imaginaryPart = sqrt(-delta) / (2 * a); printf("一元二次方程实根,有复数:%.2lf + %.2lfi\n", realPart, imaginaryPart); } } int main() { double a, b, c; printf("请输入一元二次方程的系数a, b, c:\na = "); scanf("%lf", &a); printf("b = "); scanf("%lf", &b); printf("c = "); scanf("%lf", &c); // 检查a是否为0,因为a=0不是一元二次方程 if (a != 0) { quadraticRoots(a, b, c); } else { printf("错误:a不能为0,这不构成一个一元二次方程。\n"); } return 0; } ``` 在这个程序中,首先获取用户输入的一元二次方程的系数a、b和c,然后检查a是否为零。如果a非零,则调用`quadraticRoots`函数计算并打印。如果a为零,程序会显示错误信息。
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

呆毛小叮

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

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

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

打赏作者

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

抵扣说明:

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

余额充值