蓝桥杯 p1103 C++算法训练 HERODING的蓝桥杯之路

资源限制
时间限制:1.0s 内存限制:256.0MB
  
  编程实现两个复数的运算。设有两个复数 和 ,则他们的运算公式为:

要求:(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<bits/stdc++.h>

using namespace std;

struct Plural{
	double x;
	double y;
}; 

Plural * cal(Plural p1, Plural p2, char c){
	Plural * p;
	p=(Plural *)malloc(sizeof(Plural));
	if (c == '+'){
		p->x = p1.x + p2.x;
		p->y = p1.y + p2.y;
	}
	else if(c == '-'){
		p->x = p1.x - p2.x;
		p->y = p1.y - p2.y;
	}
	else if(c == '*'){
		p->x = p1.x * p2.x - p1.y * p2.y;
		p->y = p1.x * p2.y + p1.y * p2.x;
	}
	else{
		if(p2.x == 0 || p2.y == 0){
			return NULL;
		}
		double bottom = p2.x * p2.x + p2.y * p2.y;
		p->x = (p1.x * p2.x + p1.y * p2.y) / bottom;
		p->y = (p1.y * p2.x - p1.x * p2.y) / bottom;
	}
	return p;
}

int main() {
	double a, b, c, d;
	char s;
	cin >> s >> a >> b >> c >> d;
	Plural p1, p2;
	Plural * p;
	p=(Plural *)malloc(sizeof(Plural));
	p1.x = a;
	p1.y = b;
	p2.x = c;
	p2.y = d;
	p = cal(p1, p2,s);	
	cout << fixed << setprecision(2) << p->x << "+" << p->y << "i" << endl;
	return 0;
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章