leetcode -给定一个长度为n的数组nums,数组由一些非负整数组成,现需要将他们进行排列并拼接,每个数不可拆分,使得最后的结果最大

在这里插入图片描述

解题思路:

错误方案:
大的数数字在前面,小的数字在后面 举一个反例说明一下这个方案为什么错:{9,10},排出来的最大数字是910,但是这样排的结果是109
正确方案:
对于两个数字A、B来说,如果AB>BA,那么A就应该放在B的前面。(AB表示数字A和B进行拼接)
(这个前面不一定是紧挨着B,还有可能是EACDBF这样) 比如 我现在有一些数字是这样排列的; ECDBAF 然后 AB>BA
,那么ECDABF>ECDBAF 交换了AB的顺序以后,如果AD>DA,那么A的顺序还要前移。

class s:
    def solve(self,num):
       cur = [str(n) for n in num]  // 将数组里面的值转成字符串后以列表形式显示
       // print(cur)   # ['30', '1']

       for i in range(len(cur)): // 每个数都进行一次比较
           // print('i1 = ',i)
           for j in range(i+1,len(cur)):
               // print('i2 = ',i,'j= ',j)
               // print('cur[i]=',cur[i],'cur[j]=',cur[j],type(cur[i]))
               if cur[i]+cur[j] > cur[j]+cur[i]:
                   continue
               else:
                   cur[i],cur[j] = cur[j],cur[i]
           // print(cur)
       print(''.join(cur))
s().solve([2,20,23,4,8])

运行结果

i1 =  0
i2 =  0 j=  1
cur[i]= 2 cur[j]= 20 <class 'str'>
i2 =  0 j=  2
cur[i]= 2 cur[j]= 23 <class 'str'>
i2 =  0 j=  3
cur[i]= 23 cur[j]= 4 <class 'str'>
i2 =  0 j=  4
cur[i]= 4 cur[j]= 8 <class 'str'>
['8', '20', '2', '23', '4']
i1 =  1
i2 =  1 j=  2
cur[i]= 20 cur[j]= 2 <class 'str'>
i2 =  1 j=  3
cur[i]= 2 cur[j]= 23 <class 'str'>
i2 =  1 j=  4
cur[i]= 23 cur[j]= 4 <class 'str'>
['8', '4', '20', '2', '23']
i1 =  2
i2 =  2 j=  3
cur[i]= 20 cur[j]= 2 <class 'str'>
i2 =  2 j=  4
cur[i]= 2 cur[j]= 23 <class 'str'>
['8', '4', '23', '20', '2']
i1 =  3
i2 =  3 j=  4
cur[i]= 20 cur[j]= 2 <class 'str'>
['8', '4', '23', '2', '20']
i1 =  4
['8', '4', '23', '2', '20']
8423220

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

白舟的博客

你的鼓励是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值