IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> Python常用算法代码核心逻辑【一】 -> 正文阅读

[数据结构与算法]Python常用算法代码核心逻辑【一】

记录一下,算法题中频繁使用到的算法代码块逻辑思路,学习的课程来自b站链接:清华大学博士讲解Python数据结构与算法(完整版)全套100节

汉诺塔问题

大梵天创造世界时造了三根金钢石柱子,其中一根柱子自底向上叠着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。
在这里插入图片描述

# 其实是递归的问题
def hanoi(n,a,b,c):       # n指几个,a b c指从a跟柱子出发经过b跟柱子到达c跟柱子,
    if n > 0:       #能够移动的盘子肯定要>0
        hanoi(n-1,a,c,b)       #把n-1个盘子从A经过C移动到B
        print("moving form %s to %s"% (a,c))   
        hanoi(n-1,b,a,c)     #把n-1个盘子从B经过A移动到C

hanoi(3,'A','B','C')  #A B C 三根柱子

顺序查找

时间复杂度:O(N)

def linear_search(li, val):
    for ind, v in enumerate(li):
        if v == val:
            return ind
    else:
        return None

print(linear_search([1,7,6,5,4,2,3,4,0],0))    #8

二分查找

前提是列表有序,时间复杂度为O(logN)

def binary_search(li, val):
    left = 0
    right = len(li) -1
    while left <= right:   #候选区有值
        mid = (left + right) // 2
        if li[mid] == val :
            return mid
        elif li[mid] > val:   #待查找的值在mid左侧
            right = mid - 1
        else:
            left = mid + 1    #待查找的值在mid右侧
    else:
        return None

冒泡排序Bubble Sort

原地排序,列表中每两个相邻的数,如果前面比后面大,则交换这两个数(升序)

时间复杂度:O(N)

def buble_sort(li):
    for i in range(len(li)-1):   #第i趟
        for j in range((len(li)-i-1)):
            if li[j] > li[j+1]:
                li[j], li[j+1] = li[j+1], li[j]


选择排序

原始时间复杂度:O(N2)

#原始
def select_sort_simple(li):
    li_new = []
    for i in range(len(li)):
        min_val = min(li)
        li_new.append(min_val)
        li.remove(min_val)
    return li_new

li = [3,5,1,2,6,8,2,6]
print(select_sort_simple(li))

#优化
def select_sort(li):
    for i in range(len(li) -1):   # i是第几趟
        min_loc = i
        for j in range(i+1,len(li)-1):
            if li[j] < li[min_loc]:
                min_loc = j
        li[i],li[min_loc] = li[min_loc], li[i]

插入排序

原始时间复杂度:O(N2)

def insert_sort(li):
    for i in range(1,len(li)):  # i 表示摸到的牌的下标
        temp = li[i]
        j = i - 1  #指手中的牌
        while li[j] > temp and j >= 0:
            li[j+1] = li[j]
            j -= 1
        li[j+1] = temp


快速排序

取一个元素p,使元素p归位,列表分为两部分,左边比p小,右边比p大,递归完成排序

原始时间复杂度:O(nlogn)

def partition(li,left,right):
    tmp = li[left]
    while left < right:
        while left < right and li[right] >= tmp:   #从右面找出比tmp小的数
            right -= 1  #往左走一步
        li[left] = li[right]   #右边的空位填入tmp值
        while left < right and  li[left] <= tmp:
            left += 1
        li[right] = li[left]  #把左边的值写到右边空位上
    li[left] = tmp   # tmp归位
    return left

def quick_sort(li,left,right):
    if left < right:
        mid = partition(li,left,right)
        quick_sort(li,left,mid-1)
        quick_sort(li,mid+1,right)


li = [3,4,6,7,1,2,3,8,9]
quick_sort(li,0,len(li)-1)
print(li)


  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-01-29 23:20:21  更:2022-01-29 23:22:25 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 16:16:31-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码