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;
}
相关推荐
jz_ddk5 分钟前
[实战]调频(FM)和调幅(AM)信号生成(完整C语言实现)
c语言·算法·信号处理
CloudAce云一21 分钟前
谷歌云代理商:谷歌云TPU/GPU如何加速您的AI模型训练和推理
算法
轻语呢喃1 小时前
每日LeetCode : 杨辉三角
javascript·后端·算法
YuTaoShao1 小时前
【LeetCode 热题 100】148. 排序链表——(解法二)分治
java·算法·leetcode·链表
Shilong Wang2 小时前
三维旋转沿轴分解
算法·计算机视觉·机器人
ygming2 小时前
Q43- code973- 最接近原点的 K 个点 + Q44- code347- 前 K 个高频元素
前端·算法
lightqjx2 小时前
【数据结构】顺序表(sequential list)
c语言·开发语言·数据结构·算法
ygming2 小时前
Hashmap/ Hashset- Q39~Q42内容
前端·算法
蒟蒻小袁3 小时前
力扣面试150题--全排列
算法·leetcode·面试
mit6.8243 小时前
[Backlog] 核心协调器 | 终端用户界面(TUI)实现 | 多分支任务冲突解决 | 测试验证体系
人工智能·算法