算法训练 P1103
来源:互联网 发布:js中什是键值对 编辑:程序博客网 时间:2024/05/27 09:48
编程实现两个复数的运算。设有两个复数 和 ,则他们的运算公式为:
要求:(1)定义一个结构体类型来描述复数。
(2)复数之间的加法、减法、乘法和除法分别用不用的函数来实现。
(3)必须使用结构体指针的方法把函数的计算结果返回。
说明:用户输入:运算符号(+,-,*,/) a b c d.
输出:a+bi,输出时不管a,b是小于0或等于0都按该格式输出,输出时a,b都保留两位。
输入:
- 2.5 3.6 1.5 4.9
输出:
1.00+-1.30i
解答代码
#include<iostream>#include<cstring>#include<cstdio>using namespace std;typedef struct node{float real;float imag;}NODE;//结果 NODE res;void addition(NODE num1,NODE num2){res.real=num1.real+num2.real;res.imag=num1.imag+num2.imag;} void subtraction(NODE num1,NODE num2){res.real=num1.real-num2.real;res.imag=num1.imag-num2.imag;}void multiplication(NODE num1,NODE num2){res.real=num1.real*num2.real-num1.imag*num2.imag;res.imag=num1.imag*num2.real+num1.real*num2.imag;}void division(NODE num1,NODE num2){res.real=(num1.real*num2.real+num1.imag*num2.imag)/(num2.imag*num2.imag+num2.real*num2.real);res.imag=(num1.imag*num2.real-num1.real*num2.imag)/(num2.imag*num2.imag+num2.real*num2.real);}int main(){char ch;NODE num1,num2;cin>>ch;cin>>num1.real>>num1.imag>>num2.real>>num2.imag;switch(ch){case '+':addition(num1,num2);break;case '-':subtraction(num1,num2);break;case '*':multiplication(num1,num2);break;case '/':division(num1,num2);break;}//cout<<res.real<<"+"<<res.imag<<"i"endl;printf("%.2f+%.2fi",res.real,res.imag);return 0;}
0 0
- 算法训练 P1103
- 蓝桥杯 算法训练 P1103
- 算法训练 P1103
- 算法训练 P1103
- 算法训练 P1103
- 算法训练 P1103
- 算法训练 P1103
- 算法训练 P1103
- 算法训练 P1103
- 蓝桥杯 算法训练 P1103
- 算法训练 P1103
- 蓝桥杯 算法训练 P1103
- 算法训练 P1103
- 蓝桥杯 算法训练 P1103
- 算法训练 P1103
- 算法训练 P1103 复数运算
- java蓝桥杯算法训练 P1103
- 算法训练 P1103 【复数运算,指针】
- ubuntu安装hadoop详细步骤
- HTML嵌图与创建分区响应图
- 前端常见算法js实现
- JavaScript动态获取Style样式笔记
- NAT与NAT穿越学习总结
- 算法训练 P1103
- Openlayers 2013 源码分析
- Spark在Windows下的环境搭建
- nginx反向代理、负载均衡配置
- iOS app性能优化的那些事
- 本地无法打开localhost或127.0.1解决方案
- 1031. 查验身份证(15)
- Servlet--部署在新浪云
- Linux shell 常用命令