【洛谷排序算法】P1012拼数-详细讲解

news/2025/2/23 5:49:54

在这里插入图片描述

这道题本质上是通过确定数字的拼接顺序来得到最大拼接数,虽然主要思路是利用字符串及其比较规则来实现,但也可以基于数组结合一些转换操作来解决,以下是大致思路和代码示例:

算法思路】

  • 首先将输入的数字存储在数组中。
  • 然后自定义一个比较函数,在比较函数中,将数组的数字转换为字符串进行拼接比较,从而确定数字的排序顺序。
  • 最后将排好序的数组中的数字转换为字符串并拼接输出,得到最大的拼接结果。

【代码示例】

#include<iostream>
#include<algorithm>
#include<string>
#include<vector> 
using namespace std;

//自定义比较函数
bool compare(int a,int b){
	string s1=to_string(a);
	string s2=to_string(b);
	return s1+s2>s2+s1;
}
 
int main(){
	int n;
	cin>>n;
	vector<int> nums(n);//定义vector数组,用于存放n个整数 
	for(int i=0;i<n;++i){//循环依次输入n个整数 
		cin>>nums[i];
	} 
	
	//使用自定义比较函数进行排序 
	sort(nums.begin(),nums.end(),compare);
	
	//遍历数组,拼接输出结果 
	for(int num:nums){//定义一个int类型的num变量来依次存储nums中的每个元素 
		cout<<num;
	} 
	cout<<endl;
	return 0;
}
  • 自定义比较函数:函数的返回值类型是bool,返回值将决定在排序过程中a和b的顺序关系。如果返回true,表示a应该排在b前面;如果返回false,表示b应该排在a前面。

  • 使用**to_string函数**(来自<string>头文件),将整数a和整数b分别转化为字符串s1和s2。

  • 使用**vector数组nums**而不是直接定义一个普通整型数组:vector是动态数组,避免空间浪费或空间不足的情况;vector与C++标准库中的许多算法(如sort)有很好的兼容性。在使用sort函数对vector进行排序时,不需要额外处理数组边界等问题。

  • sort排序算法函数nums 是一个 vector<int> 类型的数组,nums.begin() 返回一个指向 nums 数组第一个元素的迭代器,nums.end() 返回一个指向 nums 数组最后一个元素的下一个位置的迭代器。这样就指定了要排序的元素范围是 nums 数组中的所有元素。sort 函数在排序过程中,会不断调用这个 compare 函数来比较元素之间的大小关系,从而确定元素的最终排序顺序。例如,对于数组中的两个元素 absort 函数会调用 compare(a, b),如果返回 truea 会排在 b 前面;如果返回 falseb 会排在 a 前面。通过调用 sort 函数并传入合适的参数,我们可以方便地对 vector 数组中的元素按照自定义的规则进行排序,从而实现得到最大拼接数的目的。

  • 范围for循环

for (declaration : range) {
    // 循环体
}

范围 for 循环会自动遍历 range 中的每一个元素,将元素的值依次赋给 declaration 中声明的变量,然后执行循环体。每完成一次循环体的执行,就会获取 range 中的下一个元素,直到遍历完所有元素为止。


http://www.niftyadmin.cn/n/5863041.html

相关文章

【Linux】34.封装 UdpSocket(1)

文章目录 1. 实现一个简易的远程命令执行系统1.1 日志系统 (Log.hpp)1.2 UDP客户端 (UdpClient.cc)1.3 UDP服务器 (UdpServer.hpp)1.4 主程序 (main.c) 1. 实现一个简易的远程命令执行系统 1.1 日志系统 (Log.hpp) Log.hpp #pragma once // 防止头文件重复包含// 必要的头文…

二级公共基础之数据结构与算法篇(七)排序技术

目录 前言 一、交换类排序 1.冒泡排序法 1. 冒泡排序的思想 2. 冒泡排序的实现步骤 3. 示例 4. 冒泡排序的特点 2.快速排序 1. 快速排序的核心思想 2. 快速排序的实现步骤 3. 示例代码(C语言) 4. 快速排序的特点 二、插入类排序 1. 简单插入排序 1.简单插入排…

深入理解 Rust 中的智能指针

一、什么是智能指针&#xff1f; 智能指针是具有指针行为的数据结构&#xff0c;但它们与传统指针相比&#xff0c;提供了更多的功能。智能指针不仅拥有指向数据的能力&#xff0c;还可以管理内存&#xff0c;控制数据的所有权&#xff0c;并在不再需要时自动清理数据。Rust 通…

npm install 卡在“sill idealTree buildDeps“

问题 当你执行 npm install 时&#xff0c;你可能会遇到一个问题&#xff1a;命令卡在"sill idealTree buildDeps"这一步&#xff0c;没有任何反应 原因 这个问题的根源在于淘宝镜像源的域名过期&#xff0c;而实际上需要绑定新的镜像源。 解决方案 更换新的淘宝…

基于SpringBoot+vue+uniapp的智慧旅游小程序+LW示例参考

系列文章目录 1.基于SSM的洗衣房管理系统原生微信小程序LW参考示例 2.基于SpringBoot的宠物摄影网站管理系统LW参考示例 3.基于SpringBootVue的企业人事管理系统LW参考示例 4.基于SSM的高校实验室管理系统LW参考示例 5.基于SpringBoot的二手数码回收系统原生微信小程序LW参考示…

HAProxy介绍与编译安装

目录 1、HAProxy介绍 2、HAProxy编译安装 Centos 基础环境 Ubuntu 基础环境 编译安装HAProxy 验证HAProxy版本 HAProxy启动脚本 配置文件 启动haproxy 验证haproxy状态 查看haproxy的状态页面 1、HAProxy介绍 HAProxy是法国开发者 威利塔罗(Willy Tarreau) 在2000年…

智慧校园系统在学生学习与生活中的应用

随着科技的快速发展&#xff0c;智慧校园系统逐渐成为现代教育不可或缺的一部分。它整合了先进的信息技术、物联网技术以及人工智能等&#xff0c;旨在构建一个全面、智能、个性化的学习与生活环境。对于学生而言&#xff0c;这一系统不仅能够极大地提高学习效率&#xff0c;还…

node.js的常用指令

1. 基本指令 查看 Node.js 版本 node -v加粗样式该指令会输出当前系统中安装的 Node.js 版本号&#xff0c;有助于确认你使用的 Node.js 版本是否符合项目需求。 查看 npm 版本 npm -vnpm&#xff08;Node Package Manager&#xff09;是 Node.js 的包管理工具&#xff0c;…