概述數(shù)據(jù)結(jié)構(gòu)是組織數(shù)據(jù)的方式,,以便能夠更好的存儲和獲取數(shù)據(jù),。數(shù)據(jù)結(jié)構(gòu)定義數(shù)據(jù)之間的關系和對這些數(shù)據(jù)的操作方式。數(shù)據(jù)結(jié)構(gòu)屏蔽了數(shù)據(jù)存儲和操作的細節(jié),,讓程序員能更好的處理業(yè)務邏輯,同時擁有快速的數(shù)據(jù)存儲和獲取方式,。 在這篇文章中,,你將了解到多種數(shù)據(jù)結(jié)構(gòu)以及這些數(shù)據(jù)結(jié)構(gòu)在Python中實現(xiàn)的方式。希望大家能學以致用,! 抽象數(shù)據(jù)類型和數(shù)據(jù)結(jié)構(gòu)數(shù)據(jù)結(jié)構(gòu)是抽象數(shù)據(jù)類型(ADT)的實現(xiàn),,通常,是通過編程語言提供的基本數(shù)據(jù)類型為基礎,,結(jié)合相應的代碼來實現(xiàn),。 通常來說,數(shù)據(jù)結(jié)構(gòu)分為兩類:原始數(shù)據(jù)結(jié)構(gòu)和非原始數(shù)據(jù)結(jié)構(gòu),,原始數(shù)據(jù)結(jié)構(gòu)是用來表示簡單的數(shù)據(jù)關系,,非原始數(shù)據(jù)結(jié)構(gòu)包含原始數(shù)據(jù)結(jié)構(gòu),同時,,數(shù)據(jù)關系更加復雜,,數(shù)據(jù)操作也更加復雜。 原始數(shù)據(jù)結(jié)構(gòu)原始數(shù)據(jù)結(jié)構(gòu) - 顧名思義 - 是最原始的或基本的數(shù)據(jù)結(jié)構(gòu),。 它們是數(shù)據(jù)操作的構(gòu)建塊,,包含純粹,簡單的數(shù)據(jù)值。 Python有四種原始變量類型:
Integers您可以使用Integers表示數(shù)字數(shù)據(jù),,具體地說,,可以使用從負無窮大到無窮大的整數(shù) Float“Float”代表“浮點數(shù)”。 您可以將它用于有理數(shù),,通常以十進制數(shù)字結(jié)尾,,例如1.11或3.14。 請注意,,在Python中,,您不必顯式聲明變量或數(shù)據(jù)的類型。 那是因為Python是一種動態(tài)類型語言,。 動態(tài)類型語言是對象可以存儲的數(shù)據(jù)類型是可變的語言,。 StringString是字母,單詞或其他字符的集合,。 在Python中,,您可以通過在一對單引號或雙引號中包含一系列字符來創(chuàng)建字符串。 例如:‘cake’,,“cookie”等,。您還可以對兩個或多個字符串應用+操作來連接它們,就像下面的示例中一樣: x = 'Cake' 以下是您可以使用字符串執(zhí)行的一些其他基本操作; 例如,,您可以使用*重復字符串一定次數(shù): # Repeat 您還可以切割字符串 z1 = x[2:] 請注意,,字符串也可以是字母數(shù)字字符,但+操作仍然用于連接字符串,。 x = '4' Python有許多內(nèi)置方法或輔助函數(shù)來操作字符串,。 替換子字符串,大寫段落中的某些單詞,,在另一個字符串中查找字符串的位置是一些常見的字符串操作,。 例如:
str.capitalize('cookie')
str1 = "Cake 4 U"
str1 = "Cake 4 U"
str1 = "Cake 4 U"
str1 = 'cookie' Boolean這種內(nèi)置數(shù)據(jù)類型值為:True和False,,這通常使它們可以與整數(shù)1和0互換。布爾值在條件和比較表達式中很有用,,就像在下面的例子中一樣: x = 4 數(shù)據(jù)類型轉(zhuǎn)換有時,,你需要整型,但是接口返回給你的是字符串,,這時,,你就需要數(shù)據(jù)類型轉(zhuǎn)換,Python里,,可以使用type函數(shù)來查看數(shù)據(jù)類型,。 i = 4.0 當你把數(shù)據(jù)的類型改變時,,就稱作數(shù)據(jù)類型轉(zhuǎn)換。數(shù)據(jù)類型轉(zhuǎn)換分為兩種:隱式轉(zhuǎn)換和顯示轉(zhuǎn)換,。 隱式數(shù)據(jù)類型轉(zhuǎn)換數(shù)據(jù)類型自動轉(zhuǎn)換,,不需要指定,編譯器會為您處理,。 看看以下示例: # float 在上面的示例中,,您不必將x的數(shù)據(jù)類型顯式更改為float以執(zhí)行浮點值除法。 編譯器隱式地為你做了這個,。 顯式數(shù)據(jù)類型轉(zhuǎn)換這種類型的數(shù)據(jù)類型轉(zhuǎn)換是用戶定義的,,這意味著您必須明確地通知編譯器更改某些實體的數(shù)據(jù)類型。例如: x = 2 上面的示例,,沒有明確的告訴編譯器x,y的數(shù)據(jù)類型,,編譯器認為x為整型,y為字符串,,當你試圖連接字符串和整數(shù),,編譯器報錯了,這個問題你可以這樣解決: x = 2 python內(nèi)置了一些類型轉(zhuǎn)換函數(shù):int(), float(), 和 str() 非原始數(shù)據(jù)結(jié)構(gòu)非原始數(shù)據(jù)結(jié)構(gòu)的數(shù)據(jù)關系更加復雜,,主要包括:
Arrays 首先,,Python中的數(shù)組是一種收集基本數(shù)據(jù)類型的緊湊方式,數(shù)組中的所有條目必須具有相同的數(shù)據(jù)類型,。 但是,,與其他編程語言(如C ++或Java)不同,數(shù)組在Python中不常用,。 import array as arr ListsPython中的列表用于存儲同類項的集合。 這些是可變的,,這意味著您可以在不改變其身份的情況下更改其內(nèi)容,。 您可以通過方括號[和]來識別列表,其中包含以逗號分隔的元素,。 列表內(nèi)置于Python中:您無需單獨調(diào)用它們,。 x = [] 注意:就像您在上面的示例中看到的x1一樣,列表也可以保存異構(gòu)項,,從而滿足數(shù)組的存儲功能,。 除非您想對此集合應用某些特定操作。
list_num = [1,2,45,6,7,2,90,23,435]
list_num.insert(0, 11)
list_char.remove('o')
list_char.pop(-2) # Removes the item at the specified position Array vs List你可能想,,既然List那么方便,為什么還要Array,,這是因為由于Array存儲的數(shù)據(jù)類型一致,,可以通過簡單的函數(shù)完成一些特殊的操作。例如 array_char = array.array("u",["c","a","t","s"]) 您可以應用array_char的tostring()函數(shù),,因為Python知道數(shù)組中的所有項都具有相同的數(shù)據(jù)類型,,因此操作在每個元素上的行為方式相同。 因此,,在處理大量同類數(shù)據(jù)類型時,,數(shù)組非常有用。 因為Python不必單獨記住每個元素的數(shù)據(jù)類型細節(jié); 對于某些用途,,與列表相比,,數(shù)組可能更快并且使用更少的內(nèi)存。 在我們討論數(shù)組的主題時,,還值得提一下NumPy數(shù)組,。 NumPy數(shù)組在數(shù)據(jù)科學領域中被廣泛用于處理多維數(shù)組。 它們通常比數(shù)組模塊和Python列表更有效,。 在NumPy數(shù)組中讀取和寫入元素更快,,并且它們支持“矢量化”操作,例如元素添加,。 此外,,NumPy數(shù)組可以有效地處理大型稀疏數(shù)據(jù)集,。例如: import numpy as np 通常,列表數(shù)據(jù)結(jié)構(gòu)可以進一步分類為線性和非線性數(shù)據(jù)結(jié)構(gòu),。 堆棧和隊列稱為線性數(shù)據(jù)結(jié)構(gòu),,而圖形和樹是非線性數(shù)據(jù)結(jié)構(gòu)。 這些結(jié)構(gòu)及其概念可能相對復雜,,但由于它們與現(xiàn)實世界模型的相似性而被廣泛使用,。 注意:在線性數(shù)據(jù)結(jié)構(gòu)中,數(shù)據(jù)項按順序組織,。 數(shù)據(jù)項一個接一個地遍歷,,并且可以在單次運行期間遍歷線性數(shù)據(jù)結(jié)構(gòu)中的所有數(shù)據(jù)項。 但是,,在非線性數(shù)據(jù)結(jié)構(gòu)中,,數(shù)據(jù)項不是按順序組織的。 這意味著元素可以連接到多個元素,,以反映這些項目之間的特殊關系,。 在單次運行期間,可能無法遍歷非線性數(shù)據(jù)結(jié)構(gòu)中的所有數(shù)據(jù)項,。 Stack堆棧是根據(jù)Last-In-First-Out(LIFO)概念插入和移除的對象的容器,。 想象一下這樣一種場景,即在一個有一堆盤子的晚宴上,,總是在堆頂部添加或移除盤子,。 在計算機科學中,這個概念用于評估表達式和語法分析,,調(diào)度算法/例程等,。 可以使用Python中的列表來實現(xiàn)堆棧。 將元素添加到堆棧時,,它被稱為推送操作,,而當您刪除或刪除元素時,它被稱為彈出操作,。 請注意,當您在Python中使用堆棧時,,實際上有一個pop()方法可供使用: # Bottom -> 1 -> 2 -> 3 -> 4 -> 5 (Top) Queue 隊列是根據(jù)先進先出(FIFO)原則插入和移除的對象的容器,。 在現(xiàn)實世界中排隊的一個很好的例子是售票柜臺的線路,根據(jù)他們的到達順序上車,,因此首先到達的人也是第一個離開的人,。 Graphs 數(shù)學和計算機科學中的圖是由節(jié)點組成的網(wǎng)絡,節(jié)點也稱為頂點,,它們可以相互連接,,也可以不相互連接。 連接兩個節(jié)點的線或路徑稱為邊,。 如果邊緣具有特定的流動方向,,那么它是有向圖,方向邊緣被稱為弧,。 否則,,如果未指定方向,則該圖形稱為無向圖,。 graph = { "a" : ["c", "d"], 您可以使用Graph做一些很酷的事情,,例如嘗試找到兩個節(jié)點之間存在路徑,或者找到兩個節(jié)點之間的最短路徑,,確定圖形中的周期,。 事實上,著名的“旅行商問題”是找到一個最短路徑,,它只訪問每個節(jié)點一次并返回起點,。 有時圖形的節(jié)點或弧已經(jīng)分配了權(quán)重或成本,您可以將其視為指定行走難度級別,,并且您有興趣找到最便宜或最簡單的路徑,。 Tree現(xiàn)實世界中的一棵樹是一種生物,它的根在地上,,樹枝上有葉子,、果實。樹的分支以一種有組織的方式展開,。在計算機科學中,,樹被用來描述數(shù)據(jù)如何被組織,,除了根在頂部并且樹枝,樹葉跟隨,,向底部蔓延并且樹被繪制為與真實樹相比被倒置,。 為了引入更多的符號,根始終位于樹的頂部,。后面的其他節(jié)點稱為分支,,每個分支中的最終節(jié)點稱為葉。您可以將每個分支想象成一個較小的樹本身,。根通常稱為父節(jié)點,,它在其下面引用的節(jié)點稱為子節(jié)點。具有相同父節(jié)點的節(jié)點稱為兄弟節(jié)點,。 樹有助于定義現(xiàn)實世界場景,,并且從游戲世界到設計XML解析器,以及PDF設計原則都基于樹,。在數(shù)據(jù)科學中,,“基于決策樹的學習”實際上構(gòu)成了一個大范圍的研究。存在許多著名的方法,,如裝袋,,提升使用樹模型來生成預測模型。像國際象棋這樣的游戲構(gòu)建了一棵巨大的樹,,其中包含所有可能的動作來分析和應用啟發(fā)式方法來決定最佳操作,。 class Tree: Tuples元組是另一種標準序列數(shù)據(jù)類型。 元組和列表之間的區(qū)別在于元組是不可變的,,這意味著一旦定義,,您就無法刪除,添加或編輯其中的任何值,。 這可能在您可能將控件傳遞給其他人但您不希望它們操縱集合中的數(shù)據(jù)但可能只是在數(shù)據(jù)副本中看到它們或單獨執(zhí)行操作的情況下有用,。例如 x_tuple = 1,2,3,4,5 Dictionary如果你想實現(xiàn)類似于電話簿的東西,字典是要使用的數(shù)據(jù)結(jié)構(gòu),。 您之前看到的所有數(shù)據(jù)結(jié)構(gòu)都不適用于電話簿,。 這是一本字典可以派上用場的時候。 字典由鍵值對組成,。 x_dict = {'Edward':1, 'Jorge':2, 'Prem':3, 'Elisa':4} 您可以在詞典上應用許多其他內(nèi)置功能: len(x_dict) Sets集合是唯一對象的集合,。 這些對于創(chuàng)建僅在數(shù)據(jù)集中包含唯一值的列表很有用。 它是一個無序的集合,,但是一個可變的集合。 x_set = set('CAKE&COKE') Files文件傳統(tǒng)上是數(shù)據(jù)結(jié)構(gòu)的一部分,。 雖然大數(shù)據(jù)在數(shù)據(jù)科學行業(yè)中很常見,,但是沒有存儲和檢索先前存儲的信息的能力的編程語言幾乎沒有用,。在Python中讀取和寫入文件的語法與其他編程語言類似,但更容易處理,。 以下是一些可幫助您使用Python處理文件的基本功能:
# File modes (2nd argument): 'r'(read), 'w'(write), 'a'(appending), 'r+'(both reading and writing) open()函數(shù)中的第二個參數(shù)是打開文件模式,。 它允許您指定是要讀取(r),,寫入(w),,追加(a)還是讀取和寫入(r +)。 總結(jié)到此,,好學的你對Python的數(shù)據(jù)結(jié)構(gòu)已經(jīng)有了一個基本的了解了,。看完了歸看完了,,需要勤勞的你動手操練起來呀,! |
|
來自: 千鋒Python學堂 > 《Python基礎教程分享》