7-76 复数四则运算 (15 分)
本题要求编写程序,计算2个复数的和、差、积、商。
输入格式:
输入在一行中按照a1 b1 a2 b2
的格式给出2个复数C1=a1+b1i
和C2=a2+b2i
的实部和虚部。题目保证C2不为0。
输出格式:
分别在4行中按照(a1+b1i) 运算符 (a2+b2i) = 结果
的格式顺序输出2个复数的和、差、积、商,数字精确到小数点后1位。如果结果的实部或者虚部为0,则不输出。如果结果为0,则输出0.0。
输入样例1:
2 3.08 -2.04 5.06
结尾无空行
输出样例1:
(2.0+3.1i) + (-2.0+5.1i) = 8.1i
(2.0+3.1i) - (-2.0+5.1i) = 4.0-2.0i
(2.0+3.1i) * (-2.0+5.1i) = -19.7+3.8i
(2.0+3.1i) / (-2.0+5.1i) = 0.4-0.6i
结尾无空行
输入样例2:
1 1 -1 -1.01
输出样例2:
(1.0+1.0i) + (-1.0-1.0i) = 0.0
(1.0+1.0i) - (-1.0-1.0i) = 2.0+2.0i
(1.0+1.0i) * (-1.0-1.0i) = -2.0i
(1.0+1.0i) / (-1.0-1.0i) = -1.0
#include<iostream>
using namespace std;
int main(){
double a1,b1,a2,b2;
scanf("%lf%lf%lf%lf",&a1,&b1,&a2,&b2);
{
double a,b;
a=a1+a2;
b=b1+b2;
// cout<<a<<endl;
if(a==0&&b==0) printf("(%.1lf+%.1lfi) + (%.1lf-%.1lfi) = 0.0",a1,b1,a2,b2);
else if(a!=0&&b!=0) printf("(%.1lf+%.1lfi) + (%.1lf+%.1lfi) = %.1lf+%.1lfi\n",a1,b1,a2,b2,a,b);
else if(a==0) printf("(%.1lf+%.1lfi) + (%.1lf+%.1lfi) = %.1lfi\n",a1,b1,a2,b2,b);
else if(b==0) printf("(%.1lf+%.1lfi) + (%.1lf+%.1lfi) = %.1lf\n",a1,b1,a2,b2,a);
}
{
double a,b;
a=a1-a2;
b=b1-b2;
if(a==0&&b==0) printf("(%.1lf+%.1lfi) - (%.1lf-%.1lfi) = 0.0",a1,b1,a2,b2);
else if(a!=0&&b!=0) printf("(%.1lf+%.1lfi) - (%.1lf+%.1lfi) = %.1lf+%.1lfi\n",a1,b1,a2,b2,a,b);
else if(a==0)printf("(%.1lf+%.1lfi) - (%.1lf+%.1lfi) = %.1lfi\n",a1,b1,a2,b2,b);
else if(b==0) printf("(%.1lf+%.1lfi) - (%.1lf+%.1lfi) = %.1lf\n",a1,b1,a2,b2,a);
}
{
double a,b;
a=a1*a2-b1*b2;
b=a1*b2+a2*b1;
if(b==0) printf("(%.1lf+%.1lfi) * (%.1lf+%.1lfi) = %.1lf\n",a1,b1,a2,b2,a);
else if(a==0)printf("(%.1lf+%.1lfi) * (%.1lf+%.1lfi) = %.1lfi\n",a1,b1,a2,b2,b);
else if(a!=0&&b!=0) printf("(%.1lf+%.1lfi) * (%.1lf+%.1lfi) = %.1lf+%.1lfi\n",a1,b1,a2,b2,a,b);
else if(a==0&&b==0) printf("(%.1lf+%.1lfi) * (%.1lf+%.1lfi) = 0.0",a1,b1,a2,b2);
}
{
double a,b;
a=(a1*a2+b1*b2)/(a2*a2+b2*b2);
b=(-a1*b2+a2*b1)/(a2*a2+b2*b2);
if(b==0) printf("(%.1lf+%.1lfi) / (%.1lf+%.1lfi) = %.1lf\n",a1,b1,a2,b2,a);
else if(a==0)printf("(%.1lf+%.1lfi) / (%.1lf+%.1lfi) = %.1lfi\n",a1,b1,a2,b2,b);
else if(a!=0&&b!=0) printf("(%.1lf+%.1lfi) / (%.1lf+%.1lfi) = %.1lf+%.1lfi\n",a1,b1,a2,b2,a,b);
else if(a==0&&b==0) printf("(%.1lf+%.1lfi) / (%.1lf+%.1lfi) = 0.0",a1,b1,a2,b2);
}
return 0;
}
最先开始的思路,结果发现处理不了虚部的符号,只得运用数据结构
#include<stdio.h>
#include<stdlib.h>
typedef struct node{
double a;
double b;
}fu;
int pan(double a, double b) //判断实部和虚部是否为零
{
if(a==0&& b!=0)
return 1;
else if(a!=0 && b==0)
return 2;
else if(a==0 && b==0)
return 3;
else if(a!=0 && b!=0)
return 0;
}
double qu(double a) //四舍五入函数 只对小数点后两位做
{
double b=(int)(a*10)/10;
double s=a*100;
int p=(int)s%10;
if(abs(p)>=5)
return a<0?(b-0.1):(b+0.1);
else if(b==0)
return 0;
else if(abs(p)<5 && abs(p)>0)
return b;
else if(abs(p)==0)
return a;
}
int main()
{
double a1, b1, a2, b2;
fu f[4];
char ch[4]={'+', '-', '*', '/'};
scanf("%lf%lf%lf%lf", &a1, &b1, &a2, &b2); //输入
f[0].a=a1+a2;
f[0].b=b1+b2;
f[1].a=a1-a2;
f[1].b=b1-b2;
f[2].a=a1*a2-b1*b2;
f[2].b=a1*b2+a2*b1;
f[3].a=(a1*a2+b1*b2)/(a2*a2+b2*b2);
f[3].b=(b1*a2-a1*b2)/(a2*a2+b2*b2);
// printf("%lf\n", qu(f[3].a));
/* for(int i=0; i<4; i++)
{
printf("%.1lf %.1lf\n\n", f[i].a, f[i].b);
f[i].a=qu(f[i].a);
f[i].b=qu(f[i].b);
printf("%.1lf %.1lf\n", f[i].a, f[i].b);
}*/
for(int i=0; i<4; i++) //判断并输出
{
if(pan(qu(f[i].a), qu(f[i].b))==1)
printf("(%.1lf%+.1lfi) %c (%.1lf%+.1lfi) = %.1lfi\n", a1, b1, ch[i], a2, b2, f[i].b);
else if(pan(qu(f[i].a), qu(f[i].b))==2)
printf("(%.1lf%+.1lfi) %c (%.1lf%+.1lfi) = %.1lf\n", a1, b1, ch[i], a2, b2, f[i].a);
else if(pan(qu(f[i].a), qu(f[i].b))==3)
printf("(%.1lf%+.1lfi) %c (%.1lf%+.1lfi) = 0.0\n", a1, b1, ch[i], a2, b2);
else if(pan(qu(f[i].a), qu(f[i].b))==0)
printf("(%.1lf%+.1lfi) %c (%.1lf%+.1lfi) = %.1lf%+.1lfi\n", a1, b1, ch[i], a2, b2, f[i].a, f[i].b);
}
return 0;
}
别人的思路
#include<stdio.h>
void shizi(double x,double y); //负责打印式子
void result(double x,double y); //负责打印结果
struct Love{
double shi,xu; //表示实部,虚部
}love1,love2;
int main()
{
scanf("%lf%lf%lf%lf",&love1.shi,&love1.xu,&love2.shi,&love2.xu);
//下面的计算根据复数的实部与虚部计算公式:
//求加法的实部与虚部值
double jia_shi = love1.shi + love2.shi;
double jia_xu = love1.xu + love2.xu;
//求减法的实部与虚部值
double jian_shi = love1.shi - love2.shi;
double jian_xu = love1.xu - love2.xu;
//求乘法的实部与虚部值
double cheng_shi = love1.shi*love2.shi-love1.xu*love2.xu;
double cheng_xu = love1.xu*love2.shi+love1.shi*love2.xu;
//求除法的实部与虚部值
double chu_shi = (love1.shi*love2.shi+love1.xu*love2.xu)/(love2.shi*love2.shi+love2.xu*love2.xu);
double chu_xu = (love1.xu*love2.shi-love1.shi*love2.xu)/(love2.shi*love2.shi+love2.xu*love2.xu);
//因为题目的输出结果要分多种情况,那就在函数里来判断情况输出吧
//加法
shizi(love1.shi,love1.xu); //式子
printf(" + ");
shizi(love2.shi,love2.xu); //式子
printf(" = ");
result(jia_shi,jia_xu); //结果
//减法
shizi(love1.shi,love1.xu); //式子
printf(" - ");
shizi(love2.shi,love2.xu); //式子
printf(" = ");
result(jian_shi,jian_xu); //结果
//乘法
shizi(love1.shi,love1.xu); //式子
printf(" * ");
shizi(love2.shi,love2.xu); //式子
printf(" = ");
result(cheng_shi,cheng_xu); //结果
//除法
shizi(love1.shi,love1.xu); //式子
printf(" / ");
shizi(love2.shi,love2.xu); //式子
printf(" = ");
result(chu_shi,chu_xu); //结果
return 0;
}
void shizi(double x,double y) //负责打印式子
{
if(y<0) //虚部为负数的时候不用加'+'号
printf("(%.1lf%.1lfi)",x,y);
else
printf("(%.1lf+%.1lfi)",x,y); //反之成立
}
void result(double rshi,double rxu)
{
//虚部不存在时,只需输出实部
if(rxu<=0.05&&rxu>=-0.05) //其实这里也判断了两段都没有的情况,输出0.0
printf("%.1lf\n",rshi);
else if(rshi<=0.05&&rshi>=-0.05) //实部不存在时,输出虚部单个即可
printf("%.1lfi\n",rxu);
else if(rxu<0)
printf("%.1lf%.1lfi\n",rshi,rxu); //结果虚部为负数的时候不用加'+'号
else
printf("%.1lf+%.1lfi\n",rshi,rxu); //反之成立
}
/*虚部 实部分别进行计算
*
*
*
*/
#include<stdio.h>
#include<math.h>
void result(double a1,double b1,double a2,double b2,int i);
int main()
{
double a1,b1,a2,b2;
scanf("%lf%lf%lf%lf",&a1,&b1,&a2,&b2);
for(int i=0;i<4;i++)
{
if(i==0)
{
if(b1>=0&&b2>=0)
printf("(%.1lf+%.1lfi) + (%.1lf+%.1lfi) = ",a1,b1,a2,b2);
else if(b1<0 && b2>=0)
printf("(%.1lf%.1lfi) + (%.1lf+%.1lfi) = ",a1,b1,a2,b2);
else if(b1<0 && b2<0)
printf("(%.1lf%.1lfi) + (%.1lf%.1lfi) = ",a1,b1,a2,b2);
else
printf("(%.1lf+%.1lfi) + (%.1lf%.1lfi) = ",a1,b1,a2,b2);
result(a1,b1,a2,b2,i);
}
else if(i==1){
if(b1>=0&&b2>=0)
printf("(%.1lf+%.1lfi) - (%.1lf+%.1lfi) = ",a1,b1,a2,b2);
else if(b1<0 && b2>=0)
printf("(%.1lf%.1lfi) - (%.1lf+%.1lfi) = ",a1,b1,a2,b2);
else if(b1<0 &&b2<0)
printf("(%.1lf%.1lfi) - (%.1lf%.1lfi) = ",a1,b1,a2,b2);
else
printf("(%.1lf+%.1lfi) - (%.1lf%.1lfi) = ",a1,b1,a2,b2);
result(a1,b1,a2,b2,i);
}
else if(i==2){
if(b1>=0&&b2>=0)
printf("(%.1lf+%.1lfi) * (%.1lf+%.1lfi) = ",a1,b1,a2,b2);
else if(b1<0 && b2>=0)
printf("(%.1lf%.1lfi) * (%.1lf+%.1lfi) = ",a1,b1,a2,b2);
else if(b1<0&&b2<0)
printf("(%.1lf%.1lfi) * (%.1lf%.1lfi) = ",a1,b1,a2,b2);
else
printf("(%.1lf+%.1lfi) * (%.1lf%.1lfi) = ",a1,b1,a2,b2);
result(a1,b1,a2,b2,i);
}
else if(i==3){
if(b1>=0&&b2>=0)
printf("(%.1lf+%.1lfi) / (%.1lf+%.1lfi) = ",a1,b1,a2,b2);
else if(b1<0 && b2>=0)
printf("(%.1lf%.1lfi) / (%.1lf+%.1lfi) = ",a1,b1,a2,b2);
else if(b1<0&&b2<0)
printf("(%.1lf%.1lfi) / (%.1lf%.1lfi) = ",a1,b1,a2,b2);
else
printf("(%.1lf+%.1lfi) / (%.1lf%.1lfi) = ",a1,b1,a2,b2);
result(a1,b1,a2,b2,i);
}
}
}
void result(double a1,double b1,double a2,double b2,int i){
double really,v;
if(i==0){
really=a1+a2;
v=b1+b2;
}
else if(i==1){
really=a1-a2;
v=b1-b2;
}
else if(i==2){
really=a1*a2-b1*b2;
v=a2*b1+a1*b2;
}
else if(i==3){
/*double fenzi,fenmu;
// MultReally(a1,b1,a2,-b2)+MultV(a1,b1,a2,-b2);
fenmu=a2*a2-b2*b2;
really=MultReally(a1,b1,a2,-b2)/fenmu;
v=MultV(a1,b1,a2,-b2)/fenmu;*/
really=(a1*a2+b1*b2)/(a2*a2+b2*b2);
v=(a2*b1-a1*b2)/(a2*a2+b2*b2);
if(a2==0&&b2==0){
really=0;
v=0;
}
}
// if(really==0) printf("yes\n");
if(fabs(really)<0.1&&fabs(v)>0.1){//实部为0
printf("%.1fi\n",v);
}
else if(fabs(really)>0.1&&fabs(v)<0.1)
{//虚部为0
printf("%.1lf\n",really);
}
else if(fabs(really)>0.1&&fabs(v)>0.1){
if(v<0)
printf("%.1lf%.1lfi\n",really,v);
else
printf("%.1lf+%.1lfi\n",really,v);
}
else if(fabs(really)<0.1&&fabs(v)<0.1) printf("0.0\n");
}
#include<iostream>
using namespace std;
void reslut(double x,double y){
if(y<0.05&&y>=-0.05)printf("%.1lf\n",x);
else if(x<=0.05&&x>=-0.05)printf("%.1lfi\n",y);
else if(y<0)printf("%.1lf%.1lfi\n",x,y);
else printf("%.1lf+%.1lfi\n",x,y);
}
void shizi(double a,double b){
if(b<0)printf("(%.1lf%.1lfi)",a,b);
else printf("(%.1lf+%.1lfi)",a,b);
}
int main(){
// double a,b,c,d,x=0,y=0;
// cin>>a>>b>>c>>d;
// for(int i=0;i<4;i++){
// if(i==0){
// x=a+c;
// y=b+d;
// if(y<0.05&&y>=-0.05)printf("(%.1lf-%.1lfi) + (%.1lf+%.1lfi) = %.1lf\n",a,b,c,d,x);
// else if(x<=0.05&&x>=-0.05)printf("(%.1lf+%.1lfi) + (%.1lf+%.1lfi) = %.1lfi\n",a,b,c,d,y);
// else if(y<0)printf("(%.1lf+%.1lfi) + (%.1lf+%.1lfi) = %.1lf%.1lfi\n",a,b,c,d,x,y);
// else printf("(%.1lf+%.1lfi) + (%.1lf+%.1lfi) = %.1lf+%.1lfi\n",a,b,c,d,x,y);
// }
// if(i==1){
// x=a-c;
// y=b-d;
// if(y<0.05&&y>=-0.05)printf("(%.1lf+%.1lfi) - (%.1lf+%.1lfi) = %.1lf\n",a,b,c,d,x);
// else if(x<=0.05&&x>=-0.05)printf("(%.1lf+%.1lfi) - (%.1lf+%.1lfi) = %.1lfi\n",a,b,c,d,y);
// else if(y<0)printf("(%.1lf+%.1lfi) - (%.1lf+%.1lfi) = %.1lf%.1lfi\n",a,b,c,d,x,y);
// else printf("(%.1lf+%.1lfi) - (%.1lf+%.1lfi) = %.1lf+%.1lfi\n",a,b,c,d,x,y);
// }
// if(i==2){
// x=a*c-b*d;
// y=a*d+b*c;
// if(y<0.05&&y>=-0.05)printf("(%.1lf+%.1lfi) * (%.1lf+%.1lfi) = %.1lf\n",a,b,c,d,x);
// else if(x<=0.05&&x>=-0.05)printf("(%.1lf+%.1lfi) * (%.1lf+%.1lfi) = %.1lfi\n",a,b,c,d,y);
// else if(y<0)printf("(%.1lf+%.1lfi) * (%.1lf+%.1lfi) = %.1lf%.1lfi\n",a,b,c,d,x,y);
// else printf("(%.1lf+%.1lfi) * (%.1lf+%.1lfi) = %.1lf+%.1lfi\n",a,b,c,d,x,y);
// }
// if(i==3){
// x=(a*c+b*d)/(c*c+d*d);
// y=(-a*d+b*c)/(c*c+d*d);
// if(y<0.05&&y>=-0.05)printf("(%.1lf+%.1lfi) / (%.1lf+%.1lfi) = %.1lf\n",a,b,c,d,x);
// else if(x<=0.05&&x>=-0.05)printf("(%.1lf+%.1lfi) / (%.1lf+%.1lfi) = %.1lfi\n",a,b,c,d,y);
// else if(y<0)printf("(%.1lf+%.1lfi) / (%.1lf+%.1lfi) = %.1lf%.1lfi\n",a,b,c,d,x,y);
// else printf("(%.1lf+%.1lfi) + (%.1lf/%.1lfi) = %.1lf+%.1lfi\n",a,b,c,d,x,y);
// }
// }
double a,b,c,d,x,y;
cin>>a>>b>>c>>d;
for(int i=0;i<4;i++){
if(i==0){
x=a+c;
y=b+d;
shizi(a,b);
cout<<" + ";
shizi(c,d);
cout<<" = ";
reslut(x,y);
}
if(i==1){
x=a-c;
y=b-d;
shizi(a,b);
cout<<" - ";
shizi(c,d);
cout<<" = ";
reslut(x,y);
}
if(i==2){
x=a*c-b*d;
y=a*d+b*c;
shizi(a,b);
cout<<" * ";
shizi(c,d);
cout<<" = ";
reslut(x,y);
}
if(i==3){
x=(a*c+b*d)/(c*c+d*d);
y=(-a*d+b*c)/(c*c+d*d);
shizi(a,b);
cout<<" / ";
shizi(c,d);
cout<<" = ";
reslut(x,y);
}
}
return 0;
}