#include<stdio.h>
#include<math.h>
struct complex_s{
double x,y;
};
double real_part(struct complex_s z){
return z.x;
}
double img_part(struct complex_s z){
return z.y;
}
double magnitude(struct complex_s z){
return sqrt(z.x*z.x + z.y*z.y);
}
double angle(struct complex_s z){
return atan2(z.y, z.x);
}
struct complex_s make_from_real_img(double x, double y){
struct complex_s z;
z.x = x;
z.y = y;
return z;
}
struct complex_s make_from_mag_ang(double r, double A){
struct complex_s z;
z.x = r * cos(A);
z.y = r * sin(A);
return z;
}
struct complex_s add_complex(struct complex_s z1,struct complex_s z2){
return make_from_real_img(real_part(z1)+real_part(z2),
img_part(z1) + img_part(z2));
}
struct complex_s sub_complex(struct complex_s z1,struct complex_s z2){
return make_from_real_img(real_part(z1)-real_part(z2),
img_part(z1) - img_part(z2));
}
struct complex_s mul_complex(struct complex_s z1,struct complex_s z2){
return make_from_mag_ang(real_part(z1)*real_part(z2),
img_part(z1) + img_part(z2));
}
struct complex_s div_complex(struct complex_s z1,struct complex_s z2){
return make_from_mag_ang(real_part(z1)/real_part(z2),
img_part(z1) + img_part(z2));
}
int main(void){
struct complex_s z1 = {3.0,4.0};
struct complex_s z2= {2.0,5.0};
struct complex_s x;
x = add_complex(z1,z2);
printf("x={%f,%f}",x.x,x.y);
return 0;
}
[root@localhost struct]# ./jizuobiao.out
x={5.000000,9.000000}
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有