数组排成最小的序列

本文探讨如何将字符串数组拼接成最小的序列。通过对比不同字符串拼接方式,提出了一种时间复杂度为O(nlogn)的解决方案,优于暴力求解的O(n!)。并提供了使用Java实现的代码示例。
摘要由CSDN通过智能技术生成

输入一个字符串数组,把数组里面的所有字符串拼接起来排成一个字符串,打印所拼接出来的字符串最小,例如{“1”,“12”,“123”},可以拼接出含有6个字符的字符串,其为:“112123”,“112312”,“121123”,“121231”,“123112”,“123112”,其中打印出最小的为:“112123”。

思路一:进行一个暴力求解,全部组合寻找一遍,时间复杂度O(n!),其复杂度太高不宜选择;

思路二:存在str1和str2,比较s1 = str1+str2 和s2 = str2+str1的大小进行递增排序,

如果s1<s2,s1在拼接的时候必然会排在s2的前面;

如果s1=s2,str1必然和str2相等,谁前谁后一样;

如果s1<s2, str1必然会排在str2的后面。

思路二排序的一种变

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值