当前位置: 首页 > article >正文

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;
}


http://www.kler.cn/a/386709.html

相关文章:

  • 基于微信小程序的平安驾校预约平台的设计与实现(源码+LW++远程调试+代码讲解等)
  • 计算机网络 (1)互联网的组成
  • Python的Matplotlib
  • LlamaIndex
  • Ubuntu 的 ROS 操作系统安装与测试
  • 马斯克万卡集群AI数据中心引发的科技涟漪:智算数据中心挑战与机遇的全景洞察
  • Java 面向对象编程(OOP)
  • Word表格自动跨页怎么办
  • Pr 视频过渡:沉浸式视频
  • MySQL必会知识精华7(通配符过滤)
  • 【MySQL场景题:如何保障传入id顺序与查询结果id顺序一致】---项目积累
  • 海康私有化视频平台EasyCVR视频分析设备平台流媒体协议RTMP、HTTP-FLV、HLS的简单对比
  • HTML5+css3(定位属性,position:absolute,relative,fixed,相对定位,绝对定位,固定定位,z-index属性)
  • 01、机器学习概述
  • 《EasyQuotation 与MongoDB在股市信息的奇妙融合》
  • javaFX controlsfx 控件之SpreadsheetView
  • EDUCODER头哥 SpringBoot初体验
  • 124. Raycaster(射线拾取模型)
  • Guarding the Chessboard(UVA 11214)
  • uniapp—android原生插件开发(3Android真机调试)
  • 网络--传输层协议--TCP
  • 【LeetCode每日一题】——802.找到最终的安全状态
  • C++学习笔记----10、模块、头文件及各种主题(三)---- 连接
  • VMWARE ESXI VMFS阵列故障 服务器数据恢复
  • aosp15系统窗口闪屏原生bug-dim图层相关-你会修改吗?
  • Qt教程(007):资源文件添加