今日学习在线编程题:一元二次方程

超时限制:1000ms
内存限制:65535kb
题目描述给出一个形如Ax^2+Bx+C=0的式子,问有多少个解。

输入格式:第一行:三个**整数**表示上式的A、B、C($-1e5\leqslant A,B,C\leqslant1e5$)

输出格式:第一行:一个整数,表示解的个数,如果有无数个解,请输出-1。

接下来若干行:每行一个解,请按大小顺序输出。(保留6位小数)

输入样例:1 -5 6
输出样例:
2
2.000000
3.000000

参考程序:

#include<stdio.h>
#include<math.h>
#include<stdlib.h>
using namespace std;
int main()
{
	long long a,b,c;
	scanf("%lld%lld%lld",&a,&b,&c);
	if(a==0&&b==0&&c==0)
		printf("%d",-1);
	else if(a==0&&b==0&&c!=0)
		printf("%d",0);
	else if(a==0&&b!=0)
		printf("1\n%.6lf",-double(c)/b);
	else
	{
		if(b*b-4*a*c<0)
			printf("0");
		else if(b*b-4*a*c==0)
		{
			printf("1\n");
			double x=double(-b)/2/a;
			printf("%.6lf",x);
		}
		else
		{
			printf("2\n");
			double x1=double(-b+sqrt(b*b-4*a*c))/2/a;
			double x2=double(-b-sqrt(b*b-4*a*c))/2/a;
			double t;
			if(x1>x2)
				t=x1,x1=x2,x2=t;
			printf("%.6lf\n%
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值