c++给定一组非负整数 nums,重新排列每个数的顺序(每个数不可拆分)使之组成一个最大的整数。 说明:输出结果可能非常大,所以Jim需要返回一个字符串而不是整数。使用贪心算法。
时间: 2024-02-22 13:00:57 浏览: 120
好的,这是一个经典的贪心算法题目,可以使用C++的STL中的sort函数来实现贪心策略。以下是代码实现:
```c++
#include <iostream>
#include <vector>
#include <algorithm>
#include <string>
using namespace std;
bool cmp(int x, int y) {
string a = to_string(x);
string b = to_string(y);
return a + b > b + a;
}
string largestNumber(vector<int>& nums) {
sort(nums.begin(), nums.end(), cmp);
string res;
for (int num : nums) {
res += to_string(num);
}
if (res[0] == '0') {
return "0";
}
return res;
}
int main() {
vector<int> nums = {3, 30, 34, 5, 9};
cout << largestNumber(nums) << endl;
return 0;
}
```
其中`cmp`函数是用来比较两个数在拼接后的大小关系,如`3`和`30`,拼接后为`330`和`303`,显然`330`更大,所以应该将`3`放在`30`的前面。最后再判断一下结果的第一个字符是否为`0`,如果是则返回`0`,否则返回结果字符串即可。
阅读全文