CPP贪心算法示例

设有n个正整数(n ≤ 20),将它们联接成一排,组成一个最大的多位整数。

例如:n=3时,3个整数13,312,343联接成的最大整数为:34331213

又如:n=4时,4个整数7,13,4,246联接成的最大整数为:7424613

cpp 复制代码
#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;
}
相关推荐
郝学胜-神的一滴1 分钟前
深入理解链表:从基础到实践
开发语言·数据结构·c++·算法·链表·架构
岛雨QA12 分钟前
排序算法「Java数据结构与算法学习笔记6」
数据结构·算法
熬夜有啥好16 分钟前
Linux软件编程——综合小练习
linux·算法·目录遍历·fgets·strcpy·linux内核与用户交互·strtok
民乐团扒谱机25 分钟前
【硬核解析】网易云听歌/哼歌识曲底层技术:从算法实现到工程落地(附核心公式/伪代码)
算法
Z9fish26 分钟前
sse哈工大C语言编程练习23
c语言·数据结构·算法
ArturiaZ27 分钟前
【day36】
数据结构·c++·算法
山河君31 分钟前
四麦克风声源定位实战:基于 GCC-PHAT + 最小二乘法实现 DOA
算法·音视频·语音识别·信号处理·最小二乘法·tdoa
额,不知道写啥。37 分钟前
P5354 [Ynoi Easy Round 2017] 由乃的 OJ
java·开发语言·算法
代码无bug抓狂人38 分钟前
C语言之单词方阵——深搜(很好的深搜例题)
c语言·开发语言·算法·深度优先
im_AMBER1 小时前
Leetcode 127 删除有序数组中的重复项 | 删除有序数组中的重复项 II
数据结构·学习·算法·leetcode