把数组排成最小的数--python

本文介绍如何使用Python将数组元素排列组合成最小的整数。通过探索字符串连接和排序策略,我们可以找到一种算法来解决这个问题。内容涉及字符串操作和列表处理。
摘要由CSDN通过智能技术生成
#输入一个整数数组,把数组中的所有数字拼接成一个数,打印能拼接出所有数字最小的一个。例如输入数组[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(
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值