每日一道算法题--leetcode 179--最大数--python

栏目: Python · 发布时间: 7年前

内容简介:第一反应是用冒泡排序,但是时间复杂度比较高,所以采用了python库函数简化代码。其实这道题就是要对比int(str(nums[i])+str(nums[i+1])) 和 int(str(nums[i+1])+str(nums[i]))究竟谁比较大,然后将较大的放在数组的前面,也就是逆序排列。 使用python中的sorted函数,使用key这个参数,用下面这个作为key,然后对key进行排序,再用reverse参数做逆序

【题目描述】

每日一道算法题--leetcode 179--最大数--python
【代码思路】

第一反应是用冒泡排序,但是时间复杂度比较高,所以采用了 python 库函数简化代码。其实这道题就是要对比

int(str(nums[i])+str(nums[i+1])) 和 int(str(nums[i+1])+str(nums[i]))

究竟谁比较大,然后将较大的放在数组的前面,也就是逆序排列。 使用python中的sorted函数,使用key这个参数,用下面这个作为key,然后对key进行排序,再用reverse参数做逆序

key=cmp_to_key(lambda x,y:int(x+y)-int(y+x))
复制代码

关于cmp_to_key函数的解析见这篇文章 一句话理解cmp_to_key函数

【源代码】

调用库函数的方法:
class Solution(object):
    def largestNumber(self, nums):
        """
        :type nums: List[int]
        :rtype: str
        """
        from functools import cmp_to_key 
        nums=sorted([str(i) for i in nums],key=cmp_to_key(lambda x,y:int(x+y)-int(y+x)),reverse=True)
        if int(''.join(nums))==0:return '0'
        else: return ''.join(nums)
复制代码
冒泡排序:
class Solution(object):
    def largestNumber(self, nums):
        """
        :type nums: List[int]
        :rtype: str
        """
        for i in range(len(nums)-1):
            for j in range(i+1,len(nums)):
                if int(str(nums[i])+str(nums[j]))-int(str(nums[j])+str(nums[i]))<0:
                    temp=nums[i]
                    nums[i]=nums[j]
                    nums[j]=temp
        nums=[str(i) for i in nums]
        if int(''.join(nums))==0:return '0'
        else:return ''.join(nums)
复制代码

以上所述就是小编给大家介绍的《每日一道算法题--leetcode 179--最大数--python》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

零边际成本社会

零边际成本社会

[美]杰里米·里夫金 / 赛迪研究院专家组 / 中信出版社 / 2014-11-1 / 49.00

在这本书中,《第三次工业革命》作者杰里米•里夫金开创性地探讨了极致生产力、协同共享、产消者、生物圈生活方式等全新的概念,详细地描述了数以百万计的人生产和生活模式的转变。他认为,“产消者”正在以近乎零成本的方式制作并分享自己的信息、娱乐、绿色能源和3D打印产品。他们也通过社交媒体、租赁商、合作组织以极低或零成本的模式分享汽车、住房、服装和其他物品;学生更多地参与到基于零成本模式的开放式网络课程…… ......一起来看看 《零边际成本社会》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具