z=\frac{\left (8+6i \right )\left ( 4+3i \right )}{\left ( 8+6i \right )+\left ( 4+3i \right )}

#include <stdio.h>
typedef struct{
	float realpart;
	float imagpart;
}Complex;
void assign(Complex *A,float realpart,float imagpart);
void add(Complex *c,Complex A,Complex B);
void multiply(Complex *d,Complex A,Complex B);
void divide(Complex *e,Complex A,Complex B);
 int main(){
 	Complex z1,z2,z3,z4,z;
 	float real,imag;
 	assign(&z1,8.0,6.0);
 	assign(&z2,4.0,3.0);
 	add(&z3,z1,z2);
 	multiply(&z4,z1,z2);
 	divide(&z,z3,z4);
 	printf("real=%.4f imag=%.4f",z.realpart,z.imagpart);
 }
 void assign(Complex *A,float real,float imag){
 	A->realpart=real;
 	A->imagpart=imag;
 }
void add(Complex *c,Complex A,Complex B){
	c->realpart=A.realpart+B.realpart;
 	c->imagpart=A.imagpart+B.imagpart;
}
void multiply(Complex *d,Complex A,Complex B){
	d->realpart=A.realpart*B.realpart-A.imagpart*B.imagpart;
	d->imagpart=A.realpart*B.imagpart+A.imagpart*B.realpart;
}
void divide(Complex *e,Complex A,Complex B){
	Complex c,m;
	c.realpart=A.realpart;
	c.imagpart=-A.imagpart;
	multiply(&m,c,B);
	e->realpart=m.realpart/(c.imagpart*c.imagpart+c.realpart*c.realpart);
	e->imagpart=m.imagpart/(c.imagpart*c.imagpart+c.realpart*c.realpart);
}

Logo

DAMO开发者矩阵,由阿里巴巴达摩院和中国互联网协会联合发起,致力于探讨最前沿的技术趋势与应用成果,搭建高质量的交流与分享平台,推动技术创新与产业应用链接,围绕“人工智能与新型计算”构建开放共享的开发者生态。

更多推荐