算法题(150):拼数

审题:

本题需要我们将数组中的数据经过排序,使得他们拼接后得到的数是所有拼接方案中最大的

思路:
方法一:排序贪心

贪心策略1:直接排序

如果我们直接按照数组数据的字典序进行排序,会导致部分情况出错

eg:s1 = 35 ,s2 = 357

如果按照字典序直接排,那么此时会拼接位25257,而实际上我们可以拼接出更大的数据35735,所以直接将数据的字典序进行比较是错误的

贪心策略2:规则排序

排序规则:我们可以按照拼接后的数据的字典序进行判断

eg:a,b分别为数组中的数据(以string形式存储)

a+b > b+a:说明a数据放在前面可以得到更大的数

a+b < b+a:说明b数据放在前面可以得到更大的数

判断解析:我们先用+进行字符串连接,然后根据字典序进行判断大小(其实就是整形数据的判断方法,都是从最高位开始判断大小)

补充:排序贪心的使用前提

最终结果要对所有元素进行排序,且交换相邻元素顺序的时候不会影响其他元素

解题:

cpp 复制代码
#include<iostream>
#include<algorithm>
using namespace std;
const int N = 30;
int n;
string a[N];
bool cmp(string& x, string& y)
{
	return x+y > y+x;
}
int main()
{
	cin >> n;
	for (int i = 0; i < n; i++)
	{
		cin >> a[i];
	}
	sort(a, a + n, cmp);
	for (int i = 0; i < n; i++)
	{
		cout << a[i];
	}
	return 0;
}

总体逻辑:

1.录入数据

2.按照规则进行排序

3.按照排好的顺序进行输出

其中cmp是一个仿函数,用于控制比较逻辑:

这里我们的比较逻辑是a+b > b+a就让a放前面,和前面分析的一样

P1012 [NOIP 1998 提高组] 拼数 - 洛谷

相关推荐
2401_891482179 分钟前
C++代码复杂性分析
开发语言·c++·算法
keep intensify10 分钟前
单词搜索-
算法·深度优先
zx_zx_12310 分钟前
定长滑动窗口和不定长滑动窗口
数据结构·算法
mjhcsp17 分钟前
C++ 梯度下降法(Gradient Descent):数值优化的核心迭代算法
开发语言·c++·算法
yunyun3212324 分钟前
跨语言调用C++接口
开发语言·c++·算法
m0_5180194828 分钟前
C++中的装饰器模式变体
开发语言·c++·算法
xushichao198934 分钟前
高性能密码学库
开发语言·c++·算法
m0_5180194837 分钟前
C++代码混淆与保护
开发语言·c++·算法
m0_5698814739 分钟前
C++中的智能指针详解
开发语言·c++·算法
blackicexs42 分钟前
第九周第三天
算法