题目 1028: [编程入门]自定义函数求一元二次方程

问题描述:

求方程 的根,用三个函数分别求当b^2-4ac大于0、等于0、和小于0时的根,并输出结果。从主函数输入a、b、c的值。

样例输入:

4 1 1

样例输出:

x1=-0.125+0.484i x2=-0.125-0.484i

问题分析:

首先需要了解一元函数求根,分为三种情况,分别是根的判别式大于0,等于0,小于0。

1.△=b2-4ac=0

x1=x2=-b/2a。

2.△=b2-4ac>0

x1= [-b+ (b^2-4ac)^ (1/2)]/2a,x2= [-b-(b^2-4ac)^ (1/2)]/2a。

3.△=b2-4ac>0

代码实现:

#include <stdio.h>
#include <math.h>

double big(double a,double b,double c)
{
	double data=b*b-4*a*c;
	double x1=(-b+sqrt(data))/(2*a);
	double x2=(-b-sqrt(data))/(2*a);
	    if(a==0&&b!=0)
	    {
	        printf("x1=%.3f x2=%.3f",-c/b,-c/b);
	    }
	    else
	    {
	        printf("x1=%.3f x2=%.3f",x1,x2);
	    
	    }
 } 
 
 double small(double a,double b,double c)
 {
 	double data=b*b-4*a*c;
 	double e=-b/(2*a);
	double f=sqrt(-data)/(2*a);
  	printf("x1=%.3f+%.3fi x2=%.3f-%.3fi",e,f,e,f);

 }
 
double same (double a,double b,double c)
{
	printf("x1=%.3f x2=%.3f",-b/(2*a),-b/(2*a));
}
 

int main ()
{
	double a,b,c;
	scanf("%lf %lf %lf",&a,&b,&c);
	
	double data=b*b-4*a*c;
	
	if(data > 0)
	big(a,b,c);
	if(data<0)
	small(a,b,c);
	if(data == 0)
	same(a,b,c);
	
	return 0;
}

  • 7
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值