list
- Python內(nèi)置的一種數(shù)據(jù)類型列表:list,一種有序的集合,可以隨時添加和刪除其中的元素
-
len()可以獲取list元素個數(shù);用索引來訪問的時候,索引是從0開始 - 可以倒序獲取從-1開始倒序
- list是一個可變的有序表,往list中追加元素到末尾,采用
append()來添加 - 通過
insert()結(jié)合索引位置來插入到指定位置 - 刪除list末尾的原始
pop()方法來實現(xiàn);不帶參數(shù)則默認(rèn)刪除最后一個,帶參數(shù)則刪除指定的位置 - list進(jìn)行元素替換可以直接通過索引指定位置進(jìn)行替換
- list的元素的數(shù)據(jù)類型可以不同,并且也可以是另外一個list;list里面的元素為list就形成了二維數(shù)組,類似可以為三維,四維等等
tuple
- 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
- Python內(nèi)置字典:dict的支持,在其他語言也成為map,k-v的存儲方式,速度比較快
- dict一個key只能對應(yīng)一個vaule,放多個key進(jìn)去后會把前面的值給沖掉
- 通過in方式判斷key是否存在,或者通過get判斷,該方式可以同時在獲取不到情況下給其一個值;pop的方式指定key可以將該value從dict中給進(jìn)行刪除
- dict和list對比
- dict優(yōu)點---空間換時間
- 查找和插入速度極快,不會隨著key的增加而變慢
- 需要占用大量的內(nèi)存,內(nèi)存浪費
- list缺點 -- 時間換空間
- 查找和插入時間隨著元素增加而增加
- 占用空間小,內(nèi)存少
- dict牢記第一條key必須是不可變對象;實現(xiàn)采用hash算法;因此為了保證hash準(zhǔn)確性,key的對象就不能變
set
- 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é)
- list和tuple差別,一個可變一個不可變,不可變?yōu)橹赶虿豢勺?,根?jù)實際需要來選擇
- 記住tuple的一些特殊使用性
- 理解dict和set的差別,牢記不可變對象
- 這兩個內(nèi)置的有序集合都挺方便,簡化了很多功能的實現(xiàn)都可以直接調(diào)用實現(xiàn)。
