C程序-蓝桥-复数四则运算

设计复数库,实现基本的复数加减乘除运算。
  输入时只需分别键入实部和虚部,以空格分割,两个复数之间用运算符分隔;输出时按a+bi的格式在屏幕上打印结果。参加样例输入和样例输出。
  注意考虑特殊情况,无法计算时输出字符串"error"。

样例输入

2 4 * -3 2

样例输出

-14-8i

样例输入

3 -2 + -1 3

样例输出

2+1i

 

复数四则运算

加法法则

复数的加法按照以下规定的法则进行:设z1=a+bi,z2=c+di是任意两个复数,

则它们的和是 (a+bi)+(c+di)=(a+c)+(b+d)i。

两个复数的和依然是复数,它的实部是原来两个复数实部的和,它的虚部是原来两个虚部的和。

复数的加法满足交换律和结合律

即对任意复数z1,z2,z3,有: z1+z2=z2+z1;(z1+z2)+z3=z1+(z2+z3)。

减法法则

复数的减法按照以下规定的法则进行:设z1=a+bi,z2=c+di是任意两个复数,

则它们的差是 (a+bi)-(c+di)=(a-c)+(b-d)i。

两个复数的差依然是复数,它的实部是原来两个复数实部的差,它的虚部是原来两个虚部的差。

乘除法

编辑

乘法法则

规定复数的乘法按照以下的法则进行:

设z1=a+bi,z2=c+di(a、b、c、d∈R)是任意两个复数,那么它们的积(a+bi)(c+di)=(ac-bd)+(bc+ad)i。

其实就是把两个复数相乘,类似两个多项式相乘,展开得: ac+adi+bci+bdi2,因为i2=-1,所以结果是(ac-bd)+(bc+ad)i 。两个复数的积仍然是一个复数。

在极坐标下,复数可用模长r与幅角θ表示为(r,θ)。对于复数a+bi,r=√(a²+b²),θ=arctan(b/a)。此时,复数相乘表现为幅角相加,模长相乘。

除法法则

复数除法定义:满足(c+di)(x+yi)=(a+bi)的复数x+yi(x,y∈R)叫复数a+bi除以复数c+di的商。

运算方法:可以把除法换算成乘法做,在分子分母同时乘上分母的共轭.。所谓共轭你可以理解为加减号的变换,互为共轭的两个复数相乘是个实常数。

除法运算规则:

①设复数a+bi(a,b∈R),除以c+di(c,d∈R),其商为x+yi(x,y∈R),

即(a+bi)÷(c+di)=x+yi

分母实数化分母实数化

∵(x+yi)(c+di)=(cx-dy)+(dx+cy)i

∴(cx-dy)+(dx+cy)i=a+bi

由复数相等定义可知 cx-dy=a dx+cy=b

解这个方程组,得 x=(ac+bd)/(c2+d2) y=(bc-ad)/(c2+d2)

于是有:(a+bi)/(c+di)=(ac+bd)/(c2+d2) +((bc-ad)/(c2+d2))i

②利用共轭复数将分母实数化得(见右图):

点评:①是常规方法;②是利用初中我们学习的化简无理分式时,都是采用的分母有理化思想方法,而复数c+di与复数c-di,相当于我们初中学习的 的对偶式,它们之积为1是有理数,而(c+di)·(c-di)=c2+d2是正实数.所以可以分母实数化。把这种方法叫做分母实数化法。

另外,由上述乘法法则可得另一计算方法,即幅角相减,模长相除。

 

作者注释:之前有个问题解决不了:怎么视情况保留小数点后一位、当计算出的小数位为0时则不保留小数。所以有个测试点一直不过。但是,后来查阅后学会用%g——%g用来输出实数,根据数值大小,自动选f或e格式不输出无意义的零。

 

C程序代码

#include <iostream>
#include <stdio.h>
#include <math.h>
#include <stdlib.h>
#define N 1e-6

int main( ) 
{
	float a,b,c,d,x,y;
	char ch;
	while(scanf("%f%f %c%f%f",&a,&b,&ch,&c,&d)!=EOF)//循环输入 
	{
		if(ch=='+')//加法 
		{
			x=a+c;
			y=b+d;
		}
		else if(ch=='-')//减法 
		{
			x=a-c;
			y=b-d;		
		}
		else if(ch=='*')//乘法 
		{
			x=a*c-b*d;
			y=b*c+a*d;
		}
		else if(ch=='/')//除法 
		{
			if(c==0&&d==0)//除数不能为0 
			{
				printf("error");
				continue;
			}
			x=(a*c+b*d)/(c*c+d*d);
			y=(b*c-a*d)/(c*c+d*d);
	}

		 if(y>=N)//浮点型比较大小的方式 
			printf("%g+%gi",x,y);//正数前面自身没有‘+’ 
		else if(y<N)
			printf("%g%gi",x,y);//负数前面自身有‘-’  

		
	}
	
	
	return 0;
}

C++代码:

C++能自动处理数据类型,用C++更好

#include<iostream>
using namespace std;
 
void add(double a,double b,double c,double d)
{
	cout<<a+c;
	if(b+d>=0)
	cout<<"+";
	cout<<b+d;
	cout<<'i'<<endl;
}
 
void sub(double a,double b,double c,double d)
{
	cout<<a-c;
	if(b-d>=0)
	cout<<"+";
	cout<<b-d;
	cout<<'i'<<endl;
}
 
void mul(double a,double b,double c,double d)
{
	cout<<a*c-b*d;
	if(a*d+b*c>=0)
	cout<<"+";
	cout<<a*d+b*c;
	cout<<'i'<<endl;
}
 
void div(double a,double b,double c,double d)
{
	if(c==0&&d==0)
	{
		cout<<"error"<<endl;
		return;
	}
	cout<<(a*c+b*d)/(c*c+d*d);
	if(b*c-a*d>=0)
	cout<<"+";
	cout<<(b*c-a*d)/(c*c+d*d);
	cout<<'i'<<endl;
}
 
 
 
int main()
{
	char op;
	double a,b,c,d;
	cin>>a>>b>>op>>c>>d;
	if(op=='+')
	add(a,b,c,d);
	if(op=='-')
	sub(a,b,c,d);
	if(op=='*')
	mul(a,b,c,d);
	if(op=='/')
	div(a,b,c,d);
	return 0;
}

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值