※ 引述《hohiyan (海洋)》之銘言:
: 大家好
: 我目前正在自學python,想請教是否有更好的方法來處理搜尋nested list中的資料。
: 例如一個 nested list 為 ft = [['a',10],['b',5],['c',11'],['d',3]]
: 題目為
: Function add() takes a single-character string and a ft, and modified the ft
: to increase the number of occurrences of that character by 1.
: 例如 add('a',ft) 會 return ft = [['a',11],['b',5],['c',11'],['d',3]]
: 而 add('i',ft) return ft = [['a',10],['b',5],['c',11'],['d',3],['i',1]]
要很快找到文字的次數,不要用 list 而要用 dictionary 就可以了。
list 是比較原始,方便循序搜尋的資料格式,而 dictionary 則是用標籤快速
尋找的格式。
ft = {'a':10, 'b':5, 'c':11, 'd':3}
def occur(x, ft):
return x in list(ft)
def add(x, ft):
if occur(x, ft):
ft.update({x: ft[x]+1})
else:
ft.update({x: 1})
return ft
我目前所理解的 dictionary ,大概是這樣:假設 ft 是 dictionary ,
dictionary 是一堆 key 對應到一堆 value ,有點像函數。
用 list(ft) 可以取出 ft 的 keys , keys 中每個東西是獨一的。
另外,用 ft.update({k1: v1, k2: v2}) 可以直接把 ft 中的 k1 和 k2
的對應值洗掉。
所以如果要讓對應值一直往上加,要先從 ft 把舊的對應值很快抓出來,
然後,根據舊的對應值修改為新的對應值,再洗回去。
dictionary 抓對應值的速度是 O(1) ,洗回去的速度也是 O(1) 。