蓝桥杯 算法训练 P1103
来源:互联网 发布:俄罗斯历史书籍知乎 编辑:程序博客网 时间:2024/05/19 14:17
要求:(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<iomanip>
#include<stdlib.h>
using namespace std;
typedef struct f
{
float a;
float b;
}fushu;
fushu* add(fushu a,fushu b){
fushu *c;
c = (fushu*)malloc(sizeof(fushu));
c->a = a.a + b.a;
c->b = a.b + b.b;
return c;
}
fushu* subtract(fushu a,fushu b){
fushu *c;
c = (fushu*)malloc(sizeof(fushu));
c->a = a.a - b.a;
c->b = a.b - b.b;
return c;
}
fushu* ride(fushu a,fushu b){
fushu *c;
c = (fushu*)malloc(sizeof(fushu));
c->a = a.a * b.a - a.b * b.b;
c->b = a.a * b.b + a.b * b.a;
return c;
}
fushu* divede(fushu a,fushu b){
fushu *c;
c = (fushu*)malloc(sizeof(fushu));
c->a = (a.a * b.a + a.b * b.b) / (b.a*b.a + b.b*b.b);
c->b = (a.b * b.a - a.a * b.b) / (b.a*b.a + b.b*b.b);
return c;
}
int main(){
fushu a,b,*c;
c = (fushu*)malloc(sizeof(fushu));
char s;
cin>>s>>a.a>>a.b>>b.a>>b.b;
switch(s){
case '+': c = add(a,b);break;
case '-': c = subtract(a,b);break;
case '*': c = ride(a,b);break;
case '/': c = divede(a,b);break;
}
cout<<fixed<<setprecision(2)<<c->a<<"+"<<c->b<<"i";
return 0;
}
- 蓝桥杯 算法训练 P1103
- 蓝桥杯 算法训练 P1103
- 蓝桥杯 算法训练 P1103
- 蓝桥杯 算法训练 P1103
- java蓝桥杯算法训练 P1103
- 蓝桥杯——算法训练 P1103
- 蓝桥杯 ALGO-142 算法训练 P1103
- 蓝桥杯算法训练 P1103(复数运算)
- 算法训练 P1103
- 算法训练 P1103
- 算法训练 P1103
- 算法训练 P1103
- 算法训练 P1103
- 算法训练 P1103
- 算法训练 P1103
- 算法训练 P1103
- 算法训练 P1103
- 算法训练 P1103
- php-fpm监听socket类型-解决Connection refused
- 5.1
- Reflection2017.11.8
- MVP注册登录+OkHttp网络请求+展示数据
- 小波变换
- 蓝桥杯 算法训练 P1103
- Java SE Collection
- luogu P1101 单词方阵【dfs】
- centos 安装MySQL
- SSL2843 2017年11月8日提高组T2 拆网线(树形dp)
- 计算机视觉~~~
- xgboost在python3和python2下快速安装和编译安装以及比较
- Mybatis中,当插入数据后,返回最新主键id的几种方法,及具体用法
- 磁盘与文件系统与目录