PTA练习(3)
预感可能会有自己不知道的部分,先记载下
题目
本题目要求一元二次方程的根,结果保留2位小数。
输入格式:
输入在一行中给出3个浮点系数a、b、c,中间用空格分开。
输出格式:
根据系数情况,输出不同结果:
1)如果方程有两个不相等的实数根,则每行输出一个根,先大后小;
2)如果方程有两个不相等复数根,则每行按照格式“实部+虚部i”输出一个根,先输出虚部为正的,后输出虚部为负的;
3)如果方程只有一个根,则直接输出此根;
4)如果系数都为0,则输出"Zero Equation";
5)如果a和b为0,c不为0,则输出"Not An Equation"。
就这个题目,首先看到第一眼,发现一个很重要的问题:
2)如果方程有两个不相等复数根,则每行按照格式“实部+虚部i”输出一个根,先输出虚部为正的,后输出虚部为负的;
靴靴再次提醒我是个菜鸡(捂脸痛哭),复变函数没学好,我…忘得一干二净
double re=-b*1.0/(2*a);
double im=sqrt(-x)*1.0/(2*a);`
这两句就是当△<0的时候一元二次方程的解
其中 re是实部
im是虚部
第一次测试(3的部分先随机放弃):
# include<stdio.h>
# include<math.h>
main(){
double a,b,c;
double flag1,flag2,x;
scanf("%f %f %f",&a,&b,&c);
x = sqrt(pow(b,2)-4*a*c);
flag1 = 1.0*(-b+sqrt(pow(b,2)-4*a*c))/2*a;
flag1 = 1.0*(-b-sqrt(pow(b,2)-4*a*c))/2*a;
if(a==0 && b==0 && c==0){
printf("Zero Equation");
}
else if(a==0 && b==0 && c!= 0){
printf("Not An Equation");
}
else if(flag1!=flag2){
printf("%lf",flag1);
printf("%lf",flag2);
}
else if(x == 0)
printf("%lf",flag1);
else{
printf("zzz");
}
}
我就那么随便一写,其他的做完了再来补
我来了,第二个版本:
# include<stdio.h>
# include<math.h>
main(){
double a,b,c,x;
scanf("%lf %lf %lf",&a,&b,&c);
x = b*b - 4*a*c;
if(a==0 && b==0 && c==0){
printf("Zero Equation");
}
else if(a==0 && b==0 && c!= 0){
printf("Not An Equation");
}
if(a!=0){
if(x>0){
double flag1,flag2;
flag1 = (-b+sqrt(x))/(1.0*2*a);
flag2 = (-b-sqrt(x))/(1.0*2*a);
printf("%.2lf\n",flag1);
printf("%.2lf\n",flag2);
}
else if(x<0){
if(b!=0){
double re=-b*1.0/(2*a);
double im=sqrt(-x)*1.0/(2*a);
printf("%.2lf%+.2lfi\n",re,im);
printf("%.2lf%+.2lfi\n",re,-im);
}
else{
double im=sqrt(-x)*1.0/(2*a);
printf("%.2lf%+.2lfi\n",0.0,im);
printf("%.2lf%+.2lfi\n",0.0,-im);
}
}
else{
printf("%.2lf\n",-b*1.0/(2*a));
}
}
}
其他的都对,除了两个根相等的部分,猜测应该是if else的对应关系让我搞到没完全对应的缘故,之后会再试试,可以了会来改
由于第二版一个是存在一定问题,另外还有原因就是看起来太混乱了,所以第三版:
#include <stdio.h>
#include <math.h>
main()
{
double a,b,c;
scanf("%lf %lf %lf",&a,&b,&c);
if(a!=0){
double dt=b*b-4*a*c;
if(dt>0){
double x1,x2;
x1=(-b+sqrt(dt))/(2*a);
x2=(-b-sqrt(dt))/(2*a);
printf("%.2lf\n",x1);
printf("%.2lf\n",x2);
}
else if(dt<0){
if(b!=0){
double re=-b*1.0/(2*a);
double im=sqrt(-dt)*1.0/(2*a);
printf("%.2lf%+.2lfi\n",re,im);
printf("%.2lf%+.2lfi\n",re,-im);
}
else{
double im=sqrt(-dt)*1.0/(2*a);
printf("%.2lf%+.2lfi\n",0.0,im);
printf("%.2lf%+.2lfi\n",0.0,-im);
}
}
else{
printf("%.2lf\n",-b*1.0/(2*a));
}
}
else{
if(b!=0){
printf("%.2lf\n",-c*1.0/b);
}
else{
if(0==c)
printf("Zero Equation\n");
else
printf("Not An Equation\n");
}
}
}
好吧还是要有点逻辑的写会更好