Python使用list、tuple、dict、set(四)

list


  1. Python內(nèi)置的一種數(shù)據(jù)類型列表:list,一種有序的集合,可以隨時添加和刪除其中的元素
  2. len()可以獲取list元素個數(shù);用索引來訪問的時候,索引是從0開始
  3. 可以倒序獲取從-1開始倒序
  4. list是一個可變的有序表,往list中追加元素到末尾,采用append()來添加
  5. 通過insert()結(jié)合索引位置來插入到指定位置
  6. 刪除list末尾的原始pop()方法來實現(xiàn);不帶參數(shù)則默認(rèn)刪除最后一個,帶參數(shù)則刪除指定的位置
  7. list進(jìn)行元素替換可以直接通過索引指定位置進(jìn)行替換
  8. list的元素的數(shù)據(jù)類型可以不同,并且也可以是另外一個list;list里面的元素為list就形成了二維數(shù)組,類似可以為三維,四維等等

tuple


  1. tuple:另外一種有序列表,和list非常相似,但是tuple一旦初始化就不能修改;因此沒其沒有append()、insert()方法,其他獲取元素的方法和list一樣,但不能賦值為另外的元素
  • 因為其不可變,所以代碼更安全,可以的話盡量用tuple代替list
  • 當(dāng)tuple只有一個元素的時候t = (1)括號()既可以表示tuple也可以表示數(shù)學(xué)公式中的小括號,為了防止歧義,Python規(guī)定此種情況按小括號計算而只要一個原始的tuple定時時必須加一個逗號也就是t = (1,)來消除歧義
  • “可變的”tuple


    “可變的”tuple

    tuple所謂的不變是,tuple的每個原始,指向永遠(yuǎn)不變,但是指向的list本身是可以變的

dict


  1. Python內(nèi)置字典:dict的支持,在其他語言也成為map,k-v的存儲方式,速度比較快
  2. dict一個key只能對應(yīng)一個vaule,放多個key進(jìn)去后會把前面的值給沖掉
  3. 通過in方式判斷key是否存在,或者通過get判斷,該方式可以同時在獲取不到情況下給其一個值;pop的方式指定key可以將該value從dict中給進(jìn)行刪除
  4. dict和list對比
  • dict優(yōu)點---空間換時間
    • 查找和插入速度極快,不會隨著key的增加而變慢
    • 需要占用大量的內(nèi)存,內(nèi)存浪費
  • list缺點 -- 時間換空間
    • 查找和插入時間隨著元素增加而增加
    • 占用空間小,內(nèi)存少
  • dict牢記第一條key必須是不可變對象;實現(xiàn)采用hash算法;因此為了保證hash準(zhǔn)確性,key的對象就不能變

set


  1. set和dict類似,也是一組key的集合,但不存儲value,由于key不能重復(fù),在set中,沒有重復(fù)的key。
  • 要創(chuàng)建set,需要提供一個list作為輸入集合
  • 通過add方法添加元素到set中,如果重復(fù)添加會自動去重;remove方法可以刪除元素
  • set數(shù)學(xué)上無序和無重復(fù)元素的集合,set可以做數(shù)據(jù)意義上的交接和并集操作;兩個set分別為s1和s2; s1 & s2做交集,s1 | s2做并集
  • set和dict唯一差別是沒有存儲對應(yīng)的value,原理和dict一樣,因此也不能放入可變對象;

總結(jié)


  1. list和tuple差別,一個可變一個不可變,不可變?yōu)橹赶虿豢勺?,根?jù)實際需要來選擇
  2. 記住tuple的一些特殊使用性
  3. 理解dict和set的差別,牢記不可變對象
  4. 這兩個內(nèi)置的有序集合都挺方便,簡化了很多功能的實現(xiàn)都可以直接調(diào)用實現(xiàn)。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

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

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