算法随笔(四)

冒泡排序
def bubble_sort(list):
    for i in range(1, len(list)-1):
        for j in range(0, len(list)-i):
            if list[j] > list[j+1]:
                list[j], list[j+1] = list[j+1], list[j]
    return
选择排序
def selection_sort(list):
    for i in range(0, len(list)-1):
        index = i
        for j in range(i, len(list)):
            if list[index] > list[j]:
                index = j
        list[i], list[index] = list[index], list[i]
    return
插入排序
def insertion_sort(list):
    for i in range(1, len(list)):
        index = i
        value = list[i]
        for j in range(i-1, -1, -1):
            if value < list[j]:
                index = j
                list[j], list[j+1] = list[j+1], list[j]
        if index != i:
            list[index] = value
快速排序
def quick_sort(list, left, right):
    if left < right:
        l = left
        r = right
        index = list[left]
        while l < r:
            # 从右向左找小的
            while l < r and index < list[r]:
                r -= 1
            if l < r:
                list[l] = list[r]
                l += 1
            # 从左往右找大的
            while l < r and index > list[l]:
                l += 1
            if l < r:
                list[r] = list[l]
                r -= 1
        list[l] = index
        quick_sort(list, left, l - 1)
        quick_sort(list, l + 1, right)
最大不重复子串

动态规划 记录字母前一次出现位置 dp[i] = temp + 1 if temp < i - front else i - front

    def lengthOfLongestSubstring(self, s: str) -> int:
        index = {}
        temp = res = 0
        for i in range(len(s)):
            front = index.get(s[i],-1)
            index[s[i]] = i
            temp = temp + 1 if temp < i - front else i - front
            res = max(temp,res)
        return res 
判定二叉树是否镜像
    def isSymmetric(self, root: TreeNode) -> bool:
        def isMatch(left: TreeNode,right: TreeNode):
            if not left and not right:
                return True
            if not left or not right or left.val != right.val:
                return False
            return  isMatch(left.left,right.right) and isMatch(left.right,right.left)  
        return isMatch(root.left,root.right) if root else True

链表倒数K个节点
    def getKthFromEnd(self, head: ListNode, k: int) -> ListNode:
        first = head
        second = head
        for i in range(k):
            first = first.next
        while first:
            first = first.next
            second = second.next
        return second
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值