CPP贪心算法示例

news/2024/11/6 11:11:19 标签: 算法

设有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.niftyadmin.cn/n/5740807.html

相关文章

asp.net+uniapp养老助餐管理系统 微信小程序

文章目录 项目介绍具体实现截图技术介绍mvc设计模式小程序框架以及目录结构介绍错误处理和异常处理java类核心代码部分展示详细视频演示源码获取 项目介绍 以往流浪猫狗的救助网站相关信息的管理&#xff0c;都是工作人员手工统计。这种方式不但时效性低&#xff0c;而且需要查…

Jest进阶:测试 Vue 组件

在 Vue 项目中&#xff0c;测试组件是确保应用质量和稳定性的关键步骤。Vue Test Utils 是一个专门为 Vue.js 应用程序编写的单元测试和集成测试工具库。它提供了丰富的 API&#xff0c;帮助开发者模拟用户操作、查询组件和断言测试结果&#xff0c;从而在不需要手动操作应用程…

《C++ 网络编程:高效实现 TCP/IP 与 UDP 通信》

在当今数字化时代&#xff0c;网络编程在各个领域都有着至关重要的地位。对于 C开发者来说&#xff0c;掌握高效的网络编程方法&#xff0c;特别是 TCP/IP 和 UDP 通信的实现&#xff0c;是一项极具价值的技能。这篇文章将深入探讨在 C中实现高效网络编程的要点和技巧。 一、网…

前端关闭控制台打印信息

vite配置文件里关闭打印方法 import { defineConfig } from "vite"; import react from "vitejs/plugin-react-swc"; import removeConsole from "vite-plugin-remove-console"; // https://vitejs.dev/config/ export default defineConfig({p…

Neo4j Cypher WHERE子句详解 - 初学者指南

Neo4j Cypher WHERE子句详解 - 初学者指南 前言1. WHERE子句基础1.1 WHERE子句的本质1.2 示例数据 2. 基本用法2.1 节点属性过滤2.2 关系属性过滤 3. 高级过滤技巧3.1 字符串匹配3.2 正则表达式3.3 属性存在性检查 4. 列表和范围操作4.1 IN操作符4.2 范围查询 5. 空值处理5.1 默…

Spring 设计模式之责任链模式

Spring 设计模式之责任链模式 责任链模式用到的场景java举例 责任链模式 责任链模式&#xff08;Chain of Responsibility&#xff09;是一种行为设计模式&#xff0c;它允许你将请求沿着处理者链进行传递。 每个处理者可以对请求进行处理&#xff0c;也可以将请求传递给链中的…

学习python中的pandas有没有好的教程推荐?

看到Pandas我可就不困了&#xff0c;这是我用的最多的工具。 Pandas作为Python数科领域最顶级的库之一&#xff0c;就像excel之于office&#xff0c;是处理数据必备工具。 Pandas的学习教程自然不会少&#xff0c;在Github上搜索Pandas&#xff0c;会出现超过6万个项目&#…

Node.js——fs模块-文件夹操作

1、借助Node.js的能力&#xff0c;我们可以对文件夹进行创建、读取、删除等操作 2、方法 方法 说明 mkdir/mkdirSync 创建文件夹 readdir/readdirSync 读取文件夹 rmdir/rmdirSync 删除文件夹 3、语法 其余的方法语法类似 本文的分享到此结束&#xff0c;欢迎大家评论区…