ブルーブリッジカップp 1103 C++アルゴリズムトレーニングHERODINGブルーブリッジカップの道


リソース制限時間制限:1.0 sメモリ制限:256.0 MBプログラミングで2つの複素数の演算を実現します.複数の和が2つある場合、演算式は次のようになります.
要件:(1)複数を記述する構造体タイプを定義します.(2)複素数間の加算,減算,乗算,除算はそれぞれ不要な関数で実現する.(3)構造体ポインタを用いて関数の計算結果を返さなければならない.説明:ユーザ入力:演算記号(+,-,*,/)a b c d.出力:a+bi、出力時a、bが0未満であっても0以下であってもこのフォーマットで出力し、出力時a、bは2桁保持する.
入力:-2.5 3.6 1.5 4.9出力:1.00±1.30 i
解題の構想:主な構想はやはり構造体の構築と関数の使用にあり、ここで私は1つの関数を構築して複数を計算するだけで、構想はとてもはっきりしていて、最も注意しなければならないのは演算の時に規則を把握することです.コードは次のとおりです.
#include

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;
}