精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Python 數據結構面試必問:棧、隊列、堆、二叉樹全手寫!(鏈表翻轉/堆排序吃香)

開發
面試 Python,數據結構繞不過,尤其是鏈表翻轉、堆排序,基本是必問。今天就一篇文章全搞定!

面試 Python,數據結構繞不過!

尤其是鏈表翻轉、堆排序,基本是必問。今天就一篇文章全搞定!

棧(Stack)—— 后進先出(LIFO)

手寫實現:

class Stack:
    def __init__(self):
        self.items = []

    def push(self, item):
        """入棧"""
        self.items.append(item)

    def pop(self):
        """出棧"""
        if not self.is_empty():
            return self.items.pop()

    def peek(self):
        """查看棧頂元素"""
        return self.items[-1] if not self.is_empty() else None

    def is_empty(self):
        return len(self.items) == 0

    def size(self):
        return len(self.items)

# 測試
stack = Stack()
stack.push(1)
stack.push(2)
print(stack.pop())  # 輸出 2

隊列(Queue)—— 先進先出(FIFO)

手寫實現:

from collections import deque

class Queue:
    def __init__(self):
        self.items = deque()

    def enqueue(self, item):
        """入隊"""
        self.items.append(item)

    def dequeue(self):
        """出隊"""
        if not self.is_empty():
            return self.items.popleft()

    def is_empty(self):
        return len(self.items) == 0

    def size(self):
        return len(self.items)

# 測試
queue = Queue()
queue.enqueue(1)
queue.enqueue(2)
print(queue.dequeue())  # 輸出 1

鏈表翻轉(反轉鏈表)—— 高頻必問!

單鏈表反轉:

class Node:
    def __init__(self, val):
        self.val = val
        self.next = None

def reverse_linked_list(head):
    prev = None
    curr = head
    while curr:
        next_node = curr.next  # 保存下一個節點
        curr.next = prev       # 反轉指針
        prev = curr
        curr = next_node
    return prev  # 新的頭節點

# 測試
head = Node(1)
head.next = Node(2)
head.next.next = Node(3)

new_head = reverse_linked_list(head)
while new_head:
    print(new_head.val, end=' -> ')
    new_head = new_head.next

輸出:3 -> 2 -> 1 ->

堆排序(Heap Sort)—— 手撕算法題!

基本思路:

  • 建最大堆
  • 把堆頂元素放到數組末尾,重新堆化

手寫代碼:

def heapify(arr, n, i):
    """維護堆的性質"""
    largest = i
    left = 2 * i + 1
    right = 2 * i + 2

    if left < n and arr[left] > arr[largest]:
        largest = left
    if right < n and arr[right] > arr[largest]:
        largest = right

    if largest != i:
        arr[i], arr[largest] = arr[largest], arr[i]
        heapify(arr, n, largest)

def heap_sort(arr):
    n = len(arr)

    # 建堆
    for i in range(n // 2 - 1, -1, -1):
        heapify(arr, n, i)

    # 取堆頂元素,放到末尾
    for i in range(n-1, 0, -1):
        arr[i], arr[0] = arr[0], arr[i]  # 堆頂與當前末尾交換
        heapify(arr, i, 0)

# 測試
arr = [4, 10, 3, 5, 1]
heap_sort(arr)
print(arr)  # [1, 3, 4, 5, 10]

二叉樹(Binary Tree)—— 遍歷三板斧!

定義樹節點:

class TreeNode:
    def __init__(self, val):
        self.val = val
        self.left = None
        self.right = None

前序、中序、后序遍歷(遞歸版):

def preorder(root):
    if root:
        print(root.val, end=' ')
        preorder(root.left)
        preorder(root.right)

def inorder(root):
    if root:
        inorder(root.left)
        print(root.val, end=' ')
        inorder(root.right)

def postorder(root):
    if root:
        postorder(root.left)
        postorder(root.right)
        print(root.val, end=' ')

測試構造一棵小樹:

#       1
#      / \
#     2   3
#    / \
#   4   5

root = TreeNode(1)
root.left = TreeNode(2)
root.right = TreeNode(3)
root.left.left = TreeNode(4)
root.left.right = TreeNode(5)

print("前序遍歷:")
preorder(root)

print("\n中序遍歷:")
inorder(root)

print("\n后序遍歷:")
postorder(root)

小結

知識點

備注

棧/隊列

必備基礎,手寫

鏈表翻轉

頻繁面試題,記住三個指針

堆排序

必須熟悉堆化(heapify)

二叉樹遍歷

遞歸套路要熟

責任編輯:趙寧寧 來源: Ssoul肥魚
相關推薦

2021-04-19 07:47:42

數據結構二叉樹Tree

2021-04-20 08:37:14

數據結構二叉樹

2021-04-28 20:12:27

數據結構創建

2020-11-02 09:15:47

算法與數據結構

2013-01-30 10:34:02

數據結構

2020-04-27 07:05:58

二叉樹左子樹右子樹

2021-01-07 08:12:47

數據結構二叉樹

2023-04-06 07:39:48

2021-03-19 10:25:12

Java數據結構算法

2021-04-01 10:34:18

Java編程數據結構算法

2020-09-23 18:25:40

算法二叉樹多叉樹

2020-03-27 14:29:30

數據結構

2021-03-29 10:13:47

Java編程數據結構算法

2021-03-22 09:00:22

Java數據結構算法

2020-03-06 16:08:46

堆結構堆排序應用

2018-03-15 08:31:57

二叉樹存儲結構

2022-04-18 07:01:36

二叉堆大根堆小根堆

2021-03-11 23:42:15

二叉樹數組排序

2019-08-22 09:22:44

數據結構二叉搜索樹

2018-09-29 05:31:14

二叉樹
點贊
收藏

51CTO技術棧公眾號

欧美精品18+| 国产精品久久久久久久久搜平片| 国内久久久精品| 国产精品揄拍100视频| 高清成人在线| 亚洲美女屁股眼交3| 精品国产乱码久久久久久郑州公司| av大片在线免费观看| 无需播放器亚洲| 亚洲国产高潮在线观看| www.色就是色| 国产盗摄精品一区二区酒店| 国产欧美一区二区三区网站| 国产超碰91| 特级西西444www高清大视频| 国产一区二区三区自拍| 在线观看成人黄色| 国产污在线观看| 亚洲香蕉久久| 色视频成人在线观看免| 青青草免费在线视频观看| 你懂的在线观看视频网站| 国产精品香蕉一区二区三区| 国产精品99导航| 国产乡下妇女做爰视频| 国产精品久久久久蜜臀| 亚洲毛片在线观看.| 日本高清免费在线视频| av在线播放一区| 黑人极品videos精品欧美裸| 亚洲区成人777777精品| 在线看的av网站| 91欧美一区二区| 国产厕所精品在线观看| 国产伦精品一区二区三区视频痴汉| 久久精品主播| 欧美一级片久久久久久久| 久青草视频在线观看| 天天av综合| 中文在线资源观看视频网站免费不卡| 国产精品成人99一区无码 | 波多野结衣一区| 亚洲免费av片| 中文字幕在线播放视频| caoporn成人免费视频在线| 日韩一区二区三区精品视频| 99国产精品久久久久久| 欧美日韩免费电影| 欧美亚洲丝袜传媒另类| 91激情视频在线| 日韩精品第一| 欧美在线免费观看视频| 18禁男女爽爽爽午夜网站免费| 精精国产xxxx视频在线播放| 亚洲va欧美va天堂v国产综合| 国产专区在线视频| 91高清在线观看视频| 一区二区三区.www| 成人免费a级片| 波多野结衣在线播放| 亚洲福利国产精品| 女人喷潮完整视频| 亚洲天堂导航| 欧美最猛性xxxxx直播| 能看的毛片网站| 国产成人免费| 4438x成人网最大色成网站| 久久久福利影院| 亚洲视频国产精品| 亚洲国产欧美自拍| 少妇按摩一区二区三区| 欧美日韩精品一区二区视频| 日日摸夜夜添一区| 久久高清无码视频| 亚洲在线国产日韩欧美| 国产精品久久久久久亚洲影视| 波多野结衣爱爱| 韩国精品久久久| dy888夜精品国产专区| 污污视频在线观看网站| 国产午夜精品久久久久久久| 国产对白在线播放| 麻豆视频在线看| 欧美视频一区二区三区四区| 中文字幕55页| 亚洲香蕉视频| 久久精品国产成人| 日韩av一二三区| 秋霞国产午夜精品免费视频| 91偷拍精品一区二区三区| 亚洲 小说区 图片区 都市| 国产女主播一区| 美女av免费观看| 巨茎人妖videos另类| 91精品午夜视频| 欧美xxxxx精品| 日韩欧美高清| 久久人人爽人人| 中文字幕福利视频| 成人免费av资源| 亚洲一卡二卡三卡| sm性调教片在线观看| 欧美三级资源在线| 国产精品成人无码专区| 99久久影视| 日本欧美中文字幕| 亚洲国产精品久久人人爱潘金莲 | а天堂中文在线资源| 一区久久精品| 91久久精品久久国产性色也91| 婷婷丁香花五月天| 亚洲日本在线天堂| 黄色三级视频片| 红杏一区二区三区| 久久影院免费观看| 波多野结衣绝顶大高潮| www..com久久爱| 久久视频免费在线| 黄页免费欧美| 亚洲三级黄色在线观看| 精品无码免费视频| 国产一区二区三区不卡在线观看| 欧美一区免费视频| 色在线中文字幕| 精品国产乱码久久久久久影片| 欧美美女性生活视频| 久久久久久穴| 精品一区二区三区视频日产| 手机电影在线观看| 欧美一区二区日韩| 亚洲欧洲综合网| 秋霞影院一区二区| 日本精品一区二区三区视频| 阿v视频在线观看| 精品国产免费视频| 国产亚洲精品久久久久久无几年桃 | 91一区二区三区在线观看| 欧美一级中文字幕| www.成人| 欧美xxxx做受欧美.88| 6—12呦国产精品| 中文字幕不卡一区| 黄大色黄女片18第一次| 成人羞羞视频播放网站| 国产精品久久久久久久久久免费 | 最近日韩免费视频| 国产日韩欧美激情| 亚洲福利精品视频| 色喇叭免费久久综合网| 国产欧美精品一区二区| 欧美激情视频在线播放| 欧美精品丝袜久久久中文字幕| 国产视频123区| 久久电影网站中文字幕| 椎名由奈jux491在线播放| 欧美成人一二区| 日韩有码在线观看| 国产麻豆免费观看| 亚洲愉拍自拍另类高清精品| 任你躁av一区二区三区| 亚洲毛片视频| 欧美12av| 伊人久久大香线蕉综合影院首页| 欧美成人免费观看| 风流老熟女一区二区三区| 午夜久久电影网| 亚洲自拍偷拍一区二区 | 国产成人欧美在线观看| 川上优的av在线一区二区| 欧美三级电影精品| 欧美xxxx黑人xyx性爽| 不卡在线观看av| 国产a级片免费观看| 欧美国产一级| 成人av免费在线看| 亚洲同志男男gay1069网站| 在线观看久久久久久| 国产av一区二区三区精品| 亚洲成a人v欧美综合天堂下载| 成人手机在线免费视频| 蜜臀久久久久久久| 欧美大黑帍在线播放| 在线观看欧美理论a影院| 成人免费网站在线| 欧美少妇精品| 久久精品国产91精品亚洲| 成人爽a毛片一区二区| 色综合天天综合给合国产| 久久一级免费视频| 99久久99久久久精品齐齐| 午夜免费看毛片| 伊人影院久久| 福利网在线观看| 伊人久久大香线蕉无限次| 91精品国产综合久久香蕉最新版| 91豆花视频在线播放| 日韩在线观看精品| 亚洲日本中文字幕在线| 欧美精品亚洲二区| 国产寡妇亲子伦一区二区三区四区| 亚洲欧洲另类国产综合| 51调教丨国产调教视频| 国产精品资源在线观看| 国产福利视频在线播放| 国产精品av久久久久久麻豆网| 日韩欧美在线电影| 久久动漫网址| 亚洲一区二区日本| 成人天堂yy6080亚洲高清| 久久久久久国产免费| 日本美女在线中文版| 亚洲精品中文字| 性生活黄色大片| 欧美日本一区二区在线观看| av图片在线观看| 亚洲高清视频在线| 中文字幕电影av| 国产精品美女久久久久久久久 | 久久久久久伊人| 黄色国产网站在线播放| 尤物tv国产一区| 日本一区视频| 日韩风俗一区 二区| 国产99视频在线| 欧美一区国产二区| 亚洲天堂中文网| 欧美在线视频日韩| 国产91国语对白在线| 婷婷国产v国产偷v亚洲高清| 美女视频黄免费| 亚洲女与黑人做爰| 国产极品美女在线| 自拍偷拍国产亚洲| 婷婷丁香综合网| 欧美国产成人精品| 韩国女同性做爰三级| 久久众筹精品私拍模特| 中文字幕av观看| av亚洲精华国产精华| 日韩aaaaa| 91小视频免费观看| 91av在线免费| 久久亚洲精精品中文字幕早川悠里| 中文文字幕文字幕高清| 不卡视频在线看| 波多野结衣视频播放| 91在线播放网址| 在线不卡av电影| 国产女人18水真多18精品一级做| 久久成人激情视频| 中文字幕第一区二区| 亚洲色图27p| 亚洲乱码一区二区三区在线观看| jizz亚洲少妇| 亚洲香肠在线观看| 日本一级黄色大片| 欧美视频在线观看免费网址| 永久免费无码av网站在线观看| 色视频一区二区| 中文字幕在线观看国产| 宅男噜噜噜66一区二区66| 99久久精品国产色欲| 欧美成人猛片aaaaaaa| 日日夜夜精品免费| 亚洲男人天天操| 99re热久久这里只有精品34| 久久五月天色综合| av资源在线看片| 日本精品免费观看| 香蕉久久一区| y111111国产精品久久婷婷| 精品三级在线观看视频| 视频一区二区在线观看| 亚洲色图88| 激情综合在线观看| 麻豆精品视频在线观看免费 | 久久五月婷婷丁香社区| 久久午夜精品视频| 夜夜揉揉日日人人青青一国产精品| 日本熟女一区二区| 欧美在线免费播放| 午夜精品一二三区| 亚洲人av在线影院| 超碰在线网址| 欧美亚洲一级片| 91麻豆精品| 欧美精品一区在线| 在线看片不卡| 国产精品无码专区av在线播放| 黄一区二区三区| 亚洲天堂网一区二区| 亚洲欧美综合在线精品| 国产成人愉拍精品久久 | 91sa在线看| 四虎影视成人精品国库在线观看| 国产精品国模大尺度私拍| 欧美色网址大全| 国内精品在线观看视频| 久草在线在线精品观看| 中国黄色a级片| 一区二区不卡在线播放| 男操女视频网站| 精品国偷自产国产一区| 婷婷在线视频观看| 欧美在线视频一二三| 99ri日韩精品视频| 亚洲精品国产精品国自产| 日韩一区二区免费看| 在线观看视频在线观看| 亚洲国产激情av| 亚洲天堂一区在线观看| 日韩免费高清av| 午夜激情在线观看| 国产精品av在线| 天堂一区二区三区四区| 男人天堂av片| 国产在线播精品第三| 黄色三级生活片| 日韩欧美国产激情| 三级视频在线看| 欧美激情视频一区二区| 成人免费91| 亚洲欧美日韩精品久久久| 日韩有码一区二区三区| 亚洲成人日韩在线| 红桃av永久久久| 人人妻人人玩人人澡人人爽| 欧美久久久精品| 欧美高清影院| 亚洲精品成人自拍| 美女网站色91| 亚洲色图欧美色| 欧洲精品中文字幕| av大片在线播放| 国产精品自产拍在线观| 成人av资源电影网站| 青青青国产在线视频| 久久久久久夜精品精品免费| 午夜精品久久久久久久久久久久久蜜桃| 精品日韩一区二区三区| 牛牛电影国产一区二区| 痴汉一区二区三区| 国产综合色产| 欧美日韩一区二区区别是什么| 亚洲免费观看高清在线观看| av在线亚洲天堂| 欧美日韩不卡合集视频| 91精品尤物| 亚洲熟妇无码一区二区三区| eeuss国产一区二区三区| wwwxxx亚洲| 亚洲欧洲美洲在线综合| 欧美xxx性| 亚洲乱码一区二区三区三上悠亚| 免费看日韩精品| 欧美性x x x| 日韩一区二区三区观看| 丁香花在线观看完整版电影| 国产综合色一区二区三区| 先锋a资源在线看亚洲| 午夜在线观看一区| 欧美久久久久久久久中文字幕| 色多多视频在线观看| 97久久天天综合色天天综合色hd| 黄色精品免费| 精品人妻一区二区三区视频| 欧美在线观看视频在线| 免费网站成人| 草莓视频一区| 午夜在线视频观看日韩17c| 国产成人免费观看网站| 欧美一区午夜精品| av人人综合网| 日韩亚洲视频| 国产剧情一区二区| 亚洲精品男人天堂| 北条麻妃一区二区三区中文字幕| 欧美电影院免费观看| 日韩精品xxxx| 国产精品免费aⅴ片在线观看| 亚洲av色香蕉一区二区三区| 国产91|九色| 99久久精品费精品国产| 天堂www中文在线资源| 91黄色免费版| 亚洲精品一线| 日本精品一区二区| 国产99一区视频免费| 无码人妻精品一区二区50| 久久综合88中文色鬼| 欧美天堂社区| 91网址在线观看精品| 偷拍亚洲欧洲综合| 老司机午夜在线| 欧美不卡三区| 成人永久免费视频| 一级黄色录像大片| 欧美在线视频导航| 综合视频在线| 国产破处视频在线观看|