#输入一个整数数组,把数组中的所有数字拼接成一个数,打印能拼接出所有数字最小的一个。例如输入数组[3,32,321],则打印出这3个数字能排列的最小数字321323
#思路:
# (1)可以先考虑只有两个数字的情况: [3,32] ,可以看出来 332>323 因此需要把数组改变为 [32,3] ;
# (2)对于有三个数字的情况: [3,32,321] 我们两两进行比较, 332>323 于是,将 3 与 32 交换位置变成 [32,3,321] 而 3321>3213 于是将 3 与 321 继续交换位置到 [32,321,3] ;接着我们继续使用 32 进行比较,由于 32321>32132 将 32与321 进行位置交换为 [321,32,3] 此时,将数组链接起来变成 321323 即为最小的数
# 考虑到组合后大数问题以及字符串组合可以相加,需先将整数数组转为字符串数组,然后构建比较函数,当str1+str2>str2+str1时,str1>str2,之后将字符串列表安装比较函数进行排序
def getMinNumber(
把数组排成最小的数--python
最新推荐文章于 2021-09-01 22:37:21 发布
![](https://img-home.csdnimg.cn/images/20240611030827.png)