日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

算法与数据结构(part4)--顺序表

發(fā)布時(shí)間:2023/12/19 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 算法与数据结构(part4)--顺序表 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

學(xué)習(xí)筆記,僅供參考,有錯(cuò)必糾


文章目錄

    • 算法與數(shù)據(jù)結(jié)構(gòu)–基于python
      • 順序表
        • 什么是線性表
        • 什么是順序表
      • 順序表的基本形式
      • 順序表的結(jié)構(gòu)與實(shí)現(xiàn)
        • 順序表的結(jié)構(gòu)
        • 順序表的兩種基本實(shí)現(xiàn)方式
        • 擴(kuò)容策略
      • 順序表的操作
        • 插入元素
        • 刪除元素
      • Python中的順序表
        • 列表的基本實(shí)現(xiàn)


算法與數(shù)據(jù)結(jié)構(gòu)–基于python


順序表


什么是線性表


  • 在程序中,經(jīng)常需要將一組數(shù)據(jù)元素作為整體管理和使用,我們需要?jiǎng)?chuàng)建一種元素組,并用變量記錄它們。

  • 一組數(shù)據(jù)中包含的元素個(gè)數(shù)可能發(fā)生變化(增加或刪除元素)。

  • 對(duì)于這種需求,最簡(jiǎn)單的解決方案便是將這樣一組元素看成一個(gè)序列,用元素在序列里的位置和順序,表示數(shù)據(jù)之間的某種關(guān)系。

  • 這樣的一組序列元素的組織形式,我們可以將其抽象為線性表。

  • 一個(gè)線性表是某類元素的一個(gè)集合,還記錄著元素之間的一種順序關(guān)系

  • 線性表是最基本的數(shù)據(jù)結(jié)構(gòu)之一,在實(shí)際程序中應(yīng)用非常廣泛,它還經(jīng)常被用作更復(fù)雜的數(shù)據(jù)結(jié)構(gòu)的實(shí)現(xiàn)基礎(chǔ)。


什么是順序表


根據(jù)線性表的實(shí)際存儲(chǔ)方式,分為兩種實(shí)現(xiàn)模型:

  • 順序表,將元素有順序地存放在一塊連續(xù)的存儲(chǔ)區(qū)里,元素間的順序關(guān)系由它們的存儲(chǔ)順序自然表示。

  • 鏈表,將元素存放在通過鏈接構(gòu)造起來(lái)的一系列存儲(chǔ)塊中。


順序表的基本形式


  • 基本存儲(chǔ)形式(L = [1, 2, 3])


  • 元素外置的順序表(L = [1, 2.5, true])


順序表的結(jié)構(gòu)與實(shí)現(xiàn)


順序表的結(jié)構(gòu)


一個(gè)順序表的完整信息包括兩部分:

  • 一部分是表中的元素集合;

  • 另一部分是有關(guān)表的整體情況的信息,這部分信息主要包括元素存儲(chǔ)區(qū)的容量和當(dāng)前表中已有的元素個(gè)數(shù)兩項(xiàng).


順序表的兩種基本實(shí)現(xiàn)方式


  • 一體式存儲(chǔ),類似于數(shù)組,不可變長(zhǎng)度


  • 分離式存儲(chǔ),類似于列表,可變長(zhǎng)度


擴(kuò)容策略


  • 每次擴(kuò)充增加固定數(shù)目的存儲(chǔ)位置,如每次擴(kuò)充增加10個(gè)元素位置,這種策略可稱為線性增長(zhǎng)。

  • 每次擴(kuò)充容量加倍,如每次擴(kuò)充增加一倍存儲(chǔ)空間。


順序表的操作


插入元素


在順序表中插入新元素111的三種方式:

解釋:

  • a: 在順序表的末尾插入111
  • b: 在順序表中索引為1處存入111,將索引1處原來(lái)的元素693放入順序表末尾
  • c: 在順序表中索引為1處放入111,并將后面的元素向后依次移動(dòng)1格

復(fù)雜度:

  • a: O(1)O(1)O(1)
  • b: O(1)O(1)O(1)
  • c: O(n)O(n)O(n)

刪除元素


刪除順序表中元素的三種方式:

解釋:

  • a:刪除順序表的末尾的元素
  • b: 刪除順序表中索引為1處的元素,并將末尾的元素154存放在索引1處
  • c: 刪除順序表中索引為1處的元素,并將索引1后的元素向前依次移動(dòng)1格

復(fù)雜度:

  • a: O(1)O(1)O(1)
  • b: O(1)O(1)O(1)
  • c: O(n)O(n)O(n)

Python中的順序表


Python中的list和tuple兩種類型采用了順序表的實(shí)現(xiàn)技術(shù),具有前面討論的順序表的性質(zhì);

tuple是不可變類型,即不變的順序表,因此不支持改變其內(nèi)部狀態(tài)的任何操作,而其他方面,則與list的性質(zhì)類似;


列表的基本實(shí)現(xiàn)


Python標(biāo)準(zhǔn)類型list就是一種元素個(gè)數(shù)可變的線性表,可以添加和刪除元素,并在各種操作中維持已有元素的順序(即保序),而且還具有以下行為特征:

  • 基于下標(biāo)(位置)的高效元素訪問和更新,時(shí)間復(fù)雜度為O(1)O(1)O(1),為滿足該特征,應(yīng)該采用順序表技術(shù),表中元素保存在一塊連續(xù)的存儲(chǔ)區(qū)中。

  • 允許任意加入元素,而且在不斷加入元素的過程中,表對(duì)象(id()方法得到的值)不變,為滿足該特征,就必須能更換元素存儲(chǔ)區(qū),并且為保證更換存儲(chǔ)區(qū)時(shí)list對(duì)象的標(biāo)識(shí)id不變,只能采用分離式實(shí)現(xiàn)技術(shù)。


在Python的官方實(shí)現(xiàn)中,list就是一種采用分離式技術(shù)實(shí)現(xiàn)的動(dòng)態(tài)順序表。這就是為什么用list.append(x)或list.insert(len(list), x),即尾部插入,比在指定位置插入元素效率高。


在Python的官方實(shí)現(xiàn)中,list實(shí)現(xiàn)采用了如下的策略:

  • 在建立空表(或者很小的表)時(shí),系統(tǒng)分配一塊能容納8個(gè)元素的存儲(chǔ)區(qū)。

  • 在執(zhí)行插入操作(insert或append)時(shí),如果元素存儲(chǔ)區(qū)滿就換一塊4倍大的存儲(chǔ)區(qū)。

  • 但如果此時(shí)的表已經(jīng)很大(目前的閾值為50000),則改變策略,采用加一倍的方法。引入這種改變策略的方式,是為了避免出現(xiàn)過多空閑的存儲(chǔ)位置。

總結(jié)

以上是生活随笔為你收集整理的算法与数据结构(part4)--顺序表的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。