數據結構與算法 Python語言描述 筆記

數據結構

線性表包括順序表和鏈表,python的list是順序表,鏈表一般在動態語言中不會使用。不過鏈表還是會出現在各種算法題中。

  • 單鏈表
    • 逆轉鏈表: leetcode 206
  • 雙鏈表
  • 循環單鏈表

字符串 string

有一個重要的點就是字符串的匹配問題,其中比較重要的是無回溯匹配算法(KMP算法),算法比較復雜,重要的思想在于匹配過程中不回溯。實際復雜度是O(m+n), m和n分別是匹配模式串和目標串,一般m<<n。

  • 通配符 *和?
    • * 匹配任意一個字符串
    • ?匹配任意一個字符
  • 正則表達式:內容很多,這里就不講了
    • 原始字符串:在字符串前面加r前綴,\不作為轉義符

棧 stack

隊列 queue

python3有內置的實現模塊

二叉樹

基本概念:路徑,長度,層數。都比較好理解。
root的層數為0。
二叉樹的性質:

  • 性質6.1:在非空二叉樹第i層中最多有2^i個節點
  • 性質6.2:高度為h的二叉樹最多有2^(h+1)-1個節點
  • 性質6.2:對于任何非空二叉樹,如果其葉節點的個數為n0,度數為2的節點個數為n2,那么n0=n2+1
    滿二叉樹:所有分支節點的度數都是2
  • 性質6.4: 滿二叉樹的葉節點比分支節點多一個
    擴充二叉樹:把一個二叉樹的所有節點變成度數為2的節點(就是這棵樹長了一圈葉子),舊節點叫內部節點,新節點叫外部節點。
  • 性質6.5:擴充二叉樹的外部路徑長度叫E, 內部路徑長度叫I, n是內部節點數量, E=I+2*n
    完全二叉樹:0-(h-1)層的節點都滿,并且最后一層的節點都在左邊。
  • 性質6.6:完全二叉樹節點數為n,則高度h=floor(log2n)
  • 性質6.7:完全二叉樹節點數為n, 并從0開始編號(按層次按左右)
    • root的編號是0
    • i的父節點是floor((i-1)/2)
    • if 2i+1<n, 則其left child: 2i+1 else 無left child
    • if 2i+2<n, 則其right chiild: 2i +2 else 無right child
      完全二叉樹到線性結構有自然的雙向映射
  • 深度優先遍歷 depth first traversal, depth first search, DFS
    • 先根序遍歷DLR
    • 中根序遍歷LDR
    • 后根序遍歷LRD
  • 寬度(廣度)優先遍歷, Breadth First Search, BFS:實現BFS一般要用到一個隊列

先根序DFT

def preorder(t, proc):if not t:return Noneproc(t.val)preorder(t.left)preorder(t.right)

廣度優先遍歷 BFS

def levelorder(t, proc_):q = Queue()q.put(t)while not q.empty():n = q.get()if not n:continueq.put(n.left)q.put(n.right)proc_(n.val)
  • 合并兩個二叉樹:leetcode 617

堆:一個完全二叉樹,并且,任意一個節點存放的數據先于其子節點的數據

小頂堆 大頂堆
堆和完全二叉樹

  • 堆+一個元素 ->完全二叉樹
  • 堆 去掉root 生成兩個堆
  • 上面得到的兩個堆+新的root -> 完全二叉樹
  • 堆去掉最后一個節點,還是堆
    堆可以用來構建優先隊列(py3已經實現了)
    由堆實現的優先隊列,創建的時間復雜度是O(n),插入和彈出是O(logn)
    堆還可以用來排序

heap sort python實現

def heap_sort(nums_):def siftdown(nums_i, e, begin, end):i = beginj = begin*2+1while j < end:if j + 1 < end and nums_i[j+1] < nums_i[j]:j += 1if e < nums_i[j]:breaknums_i[i] = nums_i[j]i = jj = 2*j+1nums_i[i] = eend = len(nums_)for k in range(end//2, -1, -1):siftdown(nums_, nums_[k], k, end)for k in range((end-1), 0, -1):e = nums_[k]nums_[k] = nums_[0]siftdown(nums_, e, 0, k)return nums_[::-1]

heap sort c++實現 序列是數組
c++堆排序

排序算法 sort algorithm

  • 內排序:在內存上排序
  • 外排序
    歸并是外排序的基礎
    原地排序算法:空間復雜度為O(1)

穩定性
就是原序列里有一些Key一樣的元素,排序之后能否保持不改變這部分序列的相對順序。
比如key-value pair,按照key 排序:
(0, 100), (1, 50), (1, 60), (1, 45), (-2, 80)
希望排序之后(1, 50), (1, 60), (1, 45)這三個元素的相對位置不變。

適應性
如果一個排序算法對接近有序的序列工作的更快,就稱這種算法具有適應性。

也就是說,如果本來已經快排序完了,還差一點,那么算法是能夠利用這種優勢迅速完成剩下的工作,還是推倒重來,按照原本既定的方法重新排序。

9.2 簡單排序算法

  • 插入排序:已經有一個排序完的序列,從剩余序列中順序拿出一個跟前面的序列挨個比較,尋找合適的位置插入。用于鏈表不錯
  • 選擇排序:
    • 簡單選擇排序:每次找到最小的元素放在最前面
    • 直接選擇排序算法:把找到的最小元素和已排序序列后面的元素交換位置。是一個非常爛的算法。別用。
    • 堆排序:堆排序的問題是不穩定
  • 交換排序
    • 冒泡排序
    • 交錯排序:從左向右掃描一遍,從右向左再掃描一遍

9.3快速排序

1169117-20171130173518151-983302537.png

轉載于:https://www.cnblogs.com/theodoric008/p/7899523.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/454027.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/454027.shtml
英文地址,請注明出處:http://en.pswp.cn/news/454027.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Flask 跨域問題

一、什么是跨域 跨域是指&#xff1a;瀏覽器A從服務器B獲取的靜態資源&#xff0c;包括Html、Css、Js&#xff0c;然后在Js中通過Ajax訪問C服務器的靜態資源或請求。即&#xff1a;瀏覽器A從B服務器拿的資源&#xff0c;資源中想訪問服務器C的資源。 同源策略是指&#xff1a;…

Hibernate 中配置屬性詳解(hibernate.properties)

轉自&#xff1a;https://blog.csdn.net/shudaqi2010/article/details/70324843 Hibernate能在各種不同環境下工作而設計的, 因此存在著大量的配置參數。多數配置參數都 有比較直觀的默認值, 并有隨 Hibernate一同分發的配置樣例hibernate.properties 來展示各種配置選項。 所需…

1.3 使用電腦測試MC20的電話語音功能

需要準備的硬件 MC20開發板 1個https://item.taobao.com/item.htm?id562661881042GSM/GPRS天線 1根https://item.taobao.com/item.htm?id531979567261IPEX接口轉SMA接口轉接線 1根https://item.taobao.com/item.htm?id531979903836GPS有源天線 1根https://item.taobao.com/i…

前端之 AJAX

AJAX參數詳細列表 參數名類型描述urlString(默認: 當前頁地址) 發送請求的地址。typeString(默認: "GET") 請求方式 ("POST" 、 "GET")。注意&#xff1a;其它 HTTP 請求方法&#xff0c;如 PUT 和 DELETE &#xff0c;但僅部分瀏覽器支持。tim…

buffer 和cache的區別

Cache&#xff1a;高速緩存&#xff0c;是位于CPU與主內存間的一種容量較小但速度很高的存儲器。 由于CPU的速度遠高于主內存&#xff0c;CPU直接從內存中存取數據要等待一定時間周期&#xff0c;Cache中保存著CPU剛用過或循環使用的一部分數據&#xff0c;當CPU再次使用該部分…

html5--1.18 div元素與布局

1.18 div元素與布局 1.元素的分類2.div元素與布局 1、元素的分類 塊元素:主要特征是會產生換行效果&#xff0c;自動與其他元素分離成兩行&#xff1b;通常可以作為容器在內部添加其他元素。已經學過的塊元素有&#xff1a; h1~h6;hr;ul;ol;p;table......... 內聯元素:不會產生…

python讀取excel表格太大怎么辦_Python:使用Openpyxl讀取大型Excel工作表

嘗試對load_workbook()類使用read_only True屬性,這會導致您獲得的工作表為IterableWroksheet,這意味著您只能迭代它們,您不能直接使用列/行號來訪問其中的單元格值.根據documentation,這將提供接近恒定的存儲器消耗.此外,您不需要關閉文件,語句將為您處理.示例 –import open…

五個優秀的視頻格式轉換工具

電腦、手機、DVD播放機、PSP……這么多的東西都可以播放視頻&#xff0c;但是視頻格式又千差萬別的&#xff0c;我們該怎么辦&#xff1f;這里&#xff0c;我們介紹五個功能強大且易于使用的媒體轉換器&#xff0c;用于轉換不同類型的視頻文件。 一、Super (Windows) Super是一…

前端之 HTML

HTML Web服務本質 import socketsk socket.socket() sk.bind(("127.0.0.1", 8080)) sk.listen(5)while True:conn, addr sk.accept()data conn.recv(8096)conn.send(b"HTTP/1.1 200 OK\r\n\r\n")conn.send(b"<h1>Hello world!</h1>&…

接入指南

接入概述 接入微信公眾平臺開發&#xff0c;開發者需要按照如下步驟完成&#xff1a; 1、填寫服務器配置 2、驗證服務器地址的有效性 3、依據接口文檔實現業務邏輯 下面詳細介紹這3個步驟。 第一步&#xff1a;填寫服務器配置 登錄微信公眾平臺官網后&#xff0c;在公眾平臺官網…

艾賓浩斯記憶表格excel_Excel全年學習復習計劃表(艾賓浩斯遺忘曲線)

最近準備考在職博士&#xff0c;刷刷學歷&#xff0c;不得不又拿起必考的英語來&#xff0c;發現由于這幾年敲代碼&#xff0c;日常生活詞匯忘了很多&#xff0c;只好買本考博詞匯背誦&#xff0c;不過三十而立的人背起來確實費勁了&#xff0c;所以開始尋找好的背誦方法。又想…

七個幫助你處理Web頁面層布局的jQuery插件

1.UI.Layout jQuery UI布局插件官方網站&#xff1a;http://layout.jquery-dev.com/index.cfm使用大小可折疊的嵌套面板和大量選項創建高級UI布局。布局可以創建任何你想要的UI外觀; 從簡單的標題或側邊欄到具有工具欄&#xff0c;菜單&#xff0c;幫助面板&#xff0c;狀態欄…

前端之 CSS

CSS介紹 CSS&#xff08;Cascading Style Sheet&#xff0c;層疊樣式表)定義如何顯示HTML元素。 當瀏覽器讀到一個樣式表&#xff0c;它就會按照這個樣式表來對文檔進行格式化&#xff08;渲染&#xff09;。 CSS語法 CSS實例 每個CSS樣式由兩個組成部分&#xff1a;選擇器…

在Window下編譯OpenH323

前言&#xff1a; 本文只提供VC6.0的編譯說明&#xff0c;如果想知道VC.Net下的編譯過程請參看原文。 原文 &#xff1a; http://www.voxgratia.org/docs/pwlib_windows.html#msvc_headers 作者 &#xff1a;Craig Southeren 翻譯 &#xff1a; Richard 原文…

shell中的條件判斷和比較

1 shell 的$! ,$?, $$,$ $n $1 the first parameter,$2 the second... $# The number of command-line parameters. $0 The name of current program. $? Last command or functions return value. $$ The programs PID. $! …

matlab立體坐標定位_無懼密集建筑,小天才立體定位技術帶來最強定位體驗

如今&#xff0c;在可穿戴設備市場中&#xff0c;智能手表占據相當大一部分。而作為核心功能之一的定位&#xff0c;在智能手表中發揮著不可替代的作用&#xff0c;尤其是對于兒童電話手表而言。并且&#xff0c;在技術飛速進步&#xff0c;產品迭代加快的當前&#xff0c;兒童…

vue學習問題總結(一)

使用comopontent組件報錯錯誤信息&#xff1a;vue.js:491 [Vue warn]: Unknown custom element: <todo-item> - did you register the component correctly? For recursive components, make sure to provide the "name" option.代碼&#xff1a;<p>使用…

前端之 JavaScript 基礎

JavaScript 概述 ECMAScript 和 JavaScript的關系 1996年11月&#xff0c;JavaScript 的創造者 Netscape(網景) 公司&#xff0c;決定將 JavaScript 提交給國際標準化組織 ECMA &#xff0c;希望這門語言能夠成為國際標準。次年&#xff0c;ECMA發布262號標準文件&#xff08…

TCPMP0.72RC1的編譯與移植以及自己另外做UI完整方法

我叫張挺&#xff0c;雖然開博&#xff0c;除了轉了一篇黃色文章以外&#xff0c;技術文章從來沒有寫&#xff0c;所以呢&#xff0c;感到很不好意思&#xff01;于是決定還寫一篇在網上也留點痕跡。我這里主要是介紹TCPMP的移植以及如何把這個鳥鳥整到自己的界面中來&#xff…

svga文件如何查看_電腦隱藏文件?如何查看隱藏文件 方法簡單易學

大家好&#xff0c;我是小白一鍵重裝軟件的客服。如何查看隱藏文件呢&#xff1f;有時候不小心把文件夾勾選隱藏后文件就消失了&#xff0c;到底是怎么回事呢&#xff1f;其實這個是電腦上面一些設置開啟了文件隱藏的功能哦&#xff0c;那么下面小白系統帶你了解下如何查看隱藏…