《剑指offer》(3)排序算法篇

这篇具有很好参考价值的文章主要介绍了《剑指offer》(3)排序算法篇。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

《剑指offer》(3)排序算法篇,排序算法,python,算法

class Solution:

    def duplicate(self , numbers: List[int]) -> int:

        if len(numbers) <= 1:

            return -1

        import collections

        num_dict = collections.Counter(numbers)

        res = [key for (key,value) in num_dict.items() if value > 1]

        return res[0]

《剑指offer》(3)排序算法篇,排序算法,python,算法

class Solution:

    def sort(self,num): #快排

        if len(num) <= 1:

            return num

        import random

        pivot = random.choice(num)

        left = self.sort([i for i in num if i < pivot])

        right = self.sort([i for i in num if i > pivot])

        same = [i for i in num if i == pivot]

        return left+same+right

    def GetLeastNumbers_Solution(self , input: List[int], k: int) -> List[int]:

        if k > len(input) or k == 0: #对数据进行错误判断

            return []

        res = self.sort(input)

        return res[:k]

《剑指offer》(3)排序算法篇,排序算法,python,算法

 #插入排序

class Solution:

    def __init__(self) -> None:

        self.res = []

    def Insert(self, num): #插入排序

        if len(self.res) == 0:

            self.res.append(num)

        else:

            i = 0

            while i < len(self.res):

                if num <= self.res[i]:

                    break

                i += 1

            self.res.insert(i,num)

    def GetMedian(self):

        n = len(self.res)

        if n % 2 == 0:

            return (self.res[n//2]+self.res[n//2-1])/2.0

        else:

            return self.res[n//2]

《剑指offer》(3)排序算法篇,排序算法,python,算法

class Solution:

    def merge(self,num): #使用类似于快排的方式

        if len(num) <= 1:

            return 0

        bigger = []  #比基准大的数字

        smaller = [] #比基准小的数字

        prev = num[0] #选取第一个数作为基准

        res = 0

        for i in num[1:]: #遍历剩下的数组

            if i > prev: #如果大于基准(不是逆序对)

                bigger.append(i) #放到bigger中

            else: #是逆序对

                smaller.append(i) #放到smaller中,此时对于small中的每一个数,逆序对都至少等于bigger中的个数(不考虑smaller内部情况)

                res += len(bigger) + 1 if num[i] < prev else len(bigger) #如果严格不等值,就得加上基准,否则不加

        return res+self.merge(bigger)+self.merge(smaller) #递归去查看bigger和smaller中的情况

    def InversePairs(self , nums: List[int]) -> int:

        return self.merge(nums)%1000000007文章来源地址https://www.toymoban.com/news/detail-637664.html

到了这里,关于《剑指offer》(3)排序算法篇的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • (链表) 剑指 Offer 25. 合并两个排序的链表 ——【Leetcode每日一题】

    难度:简单 输入两个递增排序的链表,合并这两个链表并使新链表中的节点仍然是递增排序的。 示例1: 输入:1-2-4, 1-3-4 输出:1-1-2-3-4-4 限制 : 0 = 链表长度 = 1000 注意:本题与 21. 合并两个有序链表 相同 💡思路: 法一:递归 将该问题可以分解成子链表,只比较当前 l1 链

    2024年02月15日
    浏览(32)
  • (排序) 剑指 Offer 45. 把数组排成最小的数 ——【Leetcode每日一题】

    难度:中等 输入一个非负整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。 示例 1: 输入: [10,2] 输出: “102” 示例 2: 输入: [3,30,34,5,9] 输出: “3033459” 提示 : 0 nums.length = 100 说明: 输出结果可能非常大,所以你需要返回一个字符串而不

    2024年02月10日
    浏览(36)
  • (排序) 剑指 Offer 51. 数组中的逆序对 ——【Leetcode每日一题】

    难度:困难 在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的总数。 示例 1: 输入: [7,5,6,4] 输出: 5 限制 : 0 = 数组长度 = 50000 💡思路:归并排序 预备知识 「 归并排序 」是用 分治 思想,分

    2024年02月11日
    浏览(34)
  • (排序) 剑指 Offer 21. 调整数组顺序使奇数位于偶数前面 ——【Leetcode每日一题】

    难度:简单 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数在数组的前半部分,所有偶数在数组的后半部分。 示例: 输入:nums = [1,2,3,4] 输出:[1,3,2,4] 注:[3,1,2,4] 也是正确的答案之一。 提示 : 0 = n u m s . l e n g t h = 50000 0 = nums.length = 50000 0 =

    2024年02月12日
    浏览(36)
  • 剑指 Offer 56 - II. 数组中数字出现的次数 II(位运算 / 哈希表 / 排序)

    链接:剑指 Offer 56 - II. 数组中数字出现的次数 II 难度:中等 在一个数组 nums 中除一个数字只出现一次之外,其他数字都出现了三次。请找出那个只出现一次的数字。 示例 1: 输入:nums = [3,4,3,3] 输出:4 示例 2: 输入:nums = [9,1,7,9,7,9,7] 输出:1 限制: 1 = nums.length = 10000 1

    2024年02月13日
    浏览(30)
  • 从零学算法 (剑指 Offer 13)

    地上有一个m行n列的方格,从坐标 [0,0] 到坐标 [m-1,n-1] 。一个机器人从坐标 [0, 0] 的格子开始移动,它每次可以向左、右、上、下移动一格(不能移动到方格外),也不能进入行坐标和列坐标的数位之和大于k的格子。例如,当k为18时,机器人能够进入方格 [35, 37] ,因为3+5+3+

    2024年02月11日
    浏览(25)
  • 从零学算法(剑指 Offer 45)

    输入一个非负整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。 示例 1: 输入: [10,2] 输出: “102” 示例 2: 输入: [3,30,34,5,9] 输出: “3033459” 我的原始人解法:直接冒泡排序,把最先应该拼接的那个数不断后移,然后拼接即可。关键就

    2024年02月10日
    浏览(24)
  • 剑指 offer 动态规划算法题:丑数

    题目描述 :我们把只包含质因子 2、3 和 5 的数称作丑数(Ugly Number)。求按从小到大的顺序的第 n 个丑数。 分析:         枚举法, 从 1 开始判断遍历,判断是否丑数(只有 2, 3, 5 作为因子),若是丑数 n 自减,直到 n 等于 1,返回即可。         动态规划法,

    2024年02月16日
    浏览(37)
  • 《剑指offer》(5)搜索算法、位运算、模拟

    方法一: class Solution:     def GetNumberOfK(self , nums: List[int], k: int) - int:         #从两边开始找,找到之后记录当前位置         left = 0         right = len(nums) - 1         if k not in nums:             return 0         start = len(nums) - 1         end = 0         while left = right:      

    2024年02月14日
    浏览(69)
  • TypeScript算法题实战——剑指 Offer篇(6)

    一支笔,一双手,一道力扣(Leetcode)做一宿! 在本文中,我们将使用TypeScript来解决剑指offer的算法题。这些问题涵盖了各种各样的主题,包括数组、字符串、链表、树、排序和搜索等。我们将使用TypeScript的强类型和面向对象的特性来解决这些问题,并通过实际的代码示例来

    2024年02月10日
    浏览(23)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包