Python 數(shù)據(jù)結(jié)構(gòu) list

列表

  • 一個(gè)隊(duì)列,一個(gè)排序整齊的隊(duì)伍
  • 列表內(nèi)的個(gè)體稱(chēng)為元素,由若干元素組成列表
  • 元素可以是任意對(duì)象(數(shù)字,字符串,對(duì)象,列表等)
  • 列表內(nèi)元素有順序,可以使用索引
  • 線性的數(shù)據(jù)結(jié)構(gòu)
  • 使用[]表示
  • 列表是可變的

列表、鏈表、queue(隊(duì)列)、stack(棧)的差異

鏈表

鏈表是一種物理存儲(chǔ)單元上非連續(xù)、非順序的存儲(chǔ)結(jié)構(gòu),數(shù)據(jù)元素的邏輯順序是通過(guò)鏈表中的指針鏈接次序?qū)崿F(xiàn)的。鏈表由一系列結(jié)點(diǎn)(鏈表中每一個(gè)元素稱(chēng)為結(jié)點(diǎn))組成,結(jié)點(diǎn)可以在運(yùn)行時(shí)動(dòng)態(tài)生成。每個(gè)結(jié)點(diǎn)包括兩個(gè)部分:一個(gè)是存儲(chǔ)數(shù)據(jù)元素的數(shù)據(jù)域,另一個(gè)是存儲(chǔ)下一個(gè)結(jié)點(diǎn)地址的指針域。 相比于線性表順序結(jié)構(gòu),操作復(fù)雜。由于不必須按順序存儲(chǔ),鏈表在插入的時(shí)候可以達(dá)到O(1)的復(fù)雜度,比另一種線性表順序表快得多,但是查找一個(gè)節(jié)點(diǎn)或者訪問(wèn)特定編號(hào)的節(jié)點(diǎn)則需要O(n)的時(shí)間,而線性表和順序表相應(yīng)的時(shí)間復(fù)雜度分別是O(logn)和O(1)。

queue

隊(duì)列是一種特殊的線性表,是一種先進(jìn)先出(FIFO)的數(shù)據(jù)結(jié)構(gòu)。它只允許在表的前端(front)進(jìn)行刪除操作,而在表的后端(rear)進(jìn)行插入操作。進(jìn)行插入操作的端稱(chēng)為隊(duì)尾,進(jìn)行刪除操作的端稱(chēng)為隊(duì)頭。隊(duì)列中沒(méi)有元素時(shí),稱(chēng)為空隊(duì)列。

stack

棧(英語(yǔ):stack)又稱(chēng)為棧或堆疊,是計(jì)算機(jī)科學(xué)中一種特殊的串列形式的抽象數(shù)據(jù)類(lèi)型,其特殊之處在于只能允許在鏈表或數(shù)組的一端(稱(chēng)為堆棧頂端指針,英語(yǔ):top)進(jìn)行加入數(shù)據(jù)(英語(yǔ):push)和輸出數(shù)據(jù)(英語(yǔ):pop)的運(yùn)算。另外棧也可以用一維數(shù)組或鏈表的形式來(lái)完成。堆棧的另外一個(gè)相對(duì)的操作方式稱(chēng)為隊(duì)列。

由于堆棧數(shù)據(jù)結(jié)構(gòu)只允許在一端進(jìn)行操作,因而按照后進(jìn)先出(LIFO, Last In First Out)的原理運(yùn)作。

列表list定義 初始化

  • list() -> new empty list
  • list(iterable) -> new list initialized from iterable's items
  • 列表不能一開(kāi)始就定義大小

列表查詢(xún)

  • index(value, [start, [stop]])

    • 通過(guò)值value,從指定區(qū)間查找列表內(nèi)的元素是否匹配
    • 匹配第一個(gè)就立即返回索引
    • 匹配不到,拋出異常ValueError
  • count(value)

    • 返回列表中匹配value的次數(shù)
  • 時(shí)間復(fù)雜度

    • index和count方法都是O(n)
    • 隨著列表數(shù)據(jù)規(guī)模的增大,而效率下降

列表增加、插入元素

  • append(object) -> None

    • 列表尾部追加元素,返回None
    • 返回None就意味著沒(méi)有新的列表產(chǎn)生,就地修改
    • 時(shí)間復(fù)雜度是O(1)
  • insert(index, object) -> None -- insert object before index

    • 在制定的索引index出插入元素object

    • 返回None就意味著沒(méi)有新的列表產(chǎn)生,就地修改

    • 時(shí)間復(fù)雜度是O(n)

    • 索引

      • 超過(guò)上界,尾部追加5
      • 超過(guò)下屆,頭部追加
  • extend(iterable) -> None -- extend list by appending elements from the iterable

    • 將可迭代對(duì)象的元素追加進(jìn)來(lái),返回None

    • 就地修改

  • + -> list

    • 連接操作,將兩個(gè)列表連接起來(lái)
    • 產(chǎn)生新的列表,原列表不變
    • 本質(zhì)上調(diào)用的是add()方法
  • * -> list

    • 重復(fù)操作,將本列表元素重復(fù)n次,返回新的列表

列表刪除元素

  • remove(value) -> None -- remove first occurrence of value.

    • 從左至右查找第一個(gè)匹配value的值,移除該元素,返回None
    • 就地修改
    • 效率O(n),每刪除一個(gè)元素其后面的元素都要往前移動(dòng)
  • pop([index]) -> item -- remove and return item at index (default last).

    • 不指定索引index,就從列表尾部彈出一個(gè)元素
    • 指定索引index,就從索引出彈出一個(gè)元素,索引超界拋出IndexError錯(cuò)誤
    • 效率O(1),指定索引的時(shí)間復(fù)雜度O(n),不指定索引O(1)
  • clear() -> None -- remove all items from L

    • 清除列表所有元素,剩下一個(gè)空列表
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容