CPP贪心算法示例
设有n个正整数(n ≤ 20),将它们联接成一排,组成一个最大的多位整数。
例如:n=3时,3个整数13,312,343联接成的最大整数为:34331213
又如:n=4时,4个整数7,13,4,246联接成的最大整数为:7424613
#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
using namespace std;
string intToStr(int x)
{
return to_string(x);//例如 12345 会变成 “12345”
}
// 比较函数,用于确定两个数字拼接后的顺序
bool compare(const int& x, const int& y) {
string xStr = intToStr(x);
string yStr = intToStr(y);
string xyStr = xStr + yStr;// + 运算符可以直接链接两个string类型函数
string yxStr = yStr + xStr;
return xyStr > yxStr; // 返回拼接后较大的那个顺序
}
int main() {
int n;
cin >> n;
vector<int> a(n);
for (int i = 0; i < n; ++i) {
cin >> a[i];
}
// 使用自定义的比较函数对向量进行排序
sort(a.begin(), a.end(), compare);//注意这里只能用迭代器不能用sort(arr, arr + n, compare)
// 输出排序后的结果
for (size_t i = 0; i < a.size(); ++i) {
cout << a[i];
}
cout << endl;
return 0;
}
原文地址:https://blog.csdn.net/ygklwyf/article/details/143527762
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!