输入一系列复数的编号、实部、虚部,按以下要求进行排序。 排序要求为:先按复数“模的整数部分”从小到大排序,如果“模的整数部分”相同,则按实部从小到大排,如果实部又相同,则按虚部从小到大排。 打印排序后的复数编号。 输入 前面若干行,分别代表若干个复数,每行3个整数a,b,p,分别代表复数编号、实部、虚部,其中:1<=a<=2000,1<=b,p<=100。 最后一行,输入0,表示结束。 输出 输出1行,若干个数字,为按要求排序之后的复数编号。 样例输入 Copy 1 2 5 2 3 3 3 4 9 4 8 7 5 8 11 6 6 9 7 4 10 8 9 3 9 9 2 10 8 6 11 2 13 0 样例输出 Copy 2 1 3 9 8 7 6 10 4 11 5
时间: 2024-04-18 15:34:08 浏览: 69
以下是对给定要求的代码优化版本:
```cpp
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
struct ComplexNumber {
int id;
int real;
int imaginary;
int modInteger;
ComplexNumber(int id, int real, int imaginary) {
this->id = id;
this->real = real;
this->imaginary = imaginary;
this->modInteger = sqrt(real * real + imaginary * imaginary);
}
};
bool compareComplexNumbers(const ComplexNumber& a, const ComplexNumber& b) {
if (a.modInteger != b.modInteger)
return a.modInteger < b.modInteger;
else if (a.real != b.real)
return a.real < b.real;
else
return a.imaginary < b.imaginary;
}
int main() {
vector<ComplexNumber> complexNumbers;
int id, real, imaginary;
while (cin >> id && id != 0) {
cin >> real >> imaginary;
complexNumbers.push_back(ComplexNumber(id, real, imaginary));
}
sort(complexNumbers.begin(), complexNumbers.end(), compareComplexNumbers);
for (const auto& complexNumber : complexNumbers) {
cout << complexNumber.id << " ";
}
return 0;
}
```
这个优化版本对原始代码进行了以下改进:
- 移除了不必要的包含文件 `<bits/stdc++.h>`,只保留了 `<iostream>` 和 `<vector>`
- 使用 `using namespace std;` 来简化代码
- 修改了 `sqrt1` 函数的命名为 `sqrt`,并在结构体 `ComplexNumber` 的构造函数中直接调用 `sqrt` 函数
- 修改了 `compareComplexNumbers` 函数,按照问题要求进行排序
- 修改了输出部分,只输出复数的编号
希望这个优化版本能够满足您的需求!
阅读全文