题解 | #复数集合#

复数集合

https://www.nowcoder.com/practice/abdd24fa839c414a9b83aa9c4ecd05cc

//土尔逊Torson 编写于2023/06/12
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <cstdio>
#include <queue>
#include <string>

using namespace std;

struct Complex {
	int real;  //实部
	int imag;  //虚部
	Complex(int a,int b):real(a),imag(b) {}
	//题目中要求比较关系由复数的模决定,但代码中并没有使用复数的模来进行比较的,而是利用模的平方来进行比较的。
	bool operator< (Complex c) const {  //重载小于号
		return real*real + imag*imag < c.real*c.real + c.imag*c.imag;
	}
};

int main() {
	int n;
	while (scanf("%d", &n) != EOF) {
		priority_queue<Complex> myPriorityQueue;
		while (n--) {
			string str;
			cin >> str;
			if (str == "Pop") {
				if (myPriorityQueue.empty()) {
					printf("empty\n");
				}
				else {
					Complex current = myPriorityQueue.top();
					myPriorityQueue.pop();
					printf("%d+i%d\n", current.real, current.imag);
					printf("SIZE = %d\n", myPriorityQueue.size());
				}
			}
			else {
				int a, b;
				scanf("%d+i%d", &a, &b);
				myPriorityQueue.push(Complex(a, b));
				printf("SIZE = %d\n", myPriorityQueue.size());
			}
		}
	}
	system("pause");
	return EXIT_SUCCESS;
}
// 64 位输出请用 printf("%lld")

全部评论

相关推荐

千疮百孔的象牙塔:我也在捣鼓im,你这个im好奇怪的样子,单看简历get不到点,im的消息及时性,消息可靠性,然后系统的可扩展性这几个关键问题都是怎么解决的从简历描述get不到,具体说消息怎么传,消息怎么推送,消息怎么存,消息安全怎么做的这些点感觉对应不起来
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务