亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

初始化空列表的字典

初始化空列表的字典

富國滬深 2022-11-01 15:58:36
我正在嘗試初始化空列表的字典以附加到它們,但是這導致了一些奇怪的行為:def solution(A):    d = dict.fromkeys(set(A), [])    for i in range(len(A)):        d[A[i]].append(i)    print(d)輸入:[3, 4, 3, 2, 3, -1, 3, 3]輸出:{2: [0, 1, 2, 3, 4, 5, 6, 7], 3: [0, 1, 2, 3, 4, 5, 6, 7], 4: [0, 1, 2, 3, 4, 5, 6, 7],-1: [0, 1, 2, 3, 4, 5, 6, 7]}dict.fromkeys似乎將所有列表初始化為指向同一列表的指針,這是發生了什么嗎?我怎么知道這將是行為/為什么會是行為?有沒有辦法告訴口譯員不要這樣做?
查看完整描述

3 回答

?
肥皂起泡泡

TA貢獻1829條經驗 獲得超6個贊

我怎么知道這是行為

Python 文檔說明了這一點并警告您:

來自keys的類方法(可迭代[,])

創建一個新字典,其中鍵來自可迭代,值設置為value。

fromkeys()是一個返回新字典的類方法。默認為None. 所有的值都只引用一個實例,因此value是一個可變對象(例如空列表)通常是沒有意義的。要獲得不同的值,請改用 dict 理解。


查看完整回答
反對 回復 2022-11-01
?
繁花不似錦

TA貢獻1851條經驗 獲得超4個贊

你所有的列表都是同一個對象。[]只是一個文字表達式,在傳遞給dict.fromkeys. 該函數如何知道如何復制任何隨機對象?

如果您想要這種行為,請選擇collections.defaultdict

from collections import defaultdict


def solution(A):

    d = defaultdict(list)  # `list` is a factory funtion that can be called repeatedly

    for i in range(len(A)):

        d[A[i]].append(i)

    print(d)

    # or, if you dislike the output (note, it is a dict already)

    # print(dict(d))


查看完整回答
反對 回復 2022-11-01
?
子衿沉夜

TA貢獻1828條經驗 獲得超3個贊

在 fromkeys 中,如果提供的值是可變的(如列表),則每個鍵的值將是對同一對象的引用,因此所有值都會立即更新。您可以通過附加到原始列表來測試這一點,以產生與您得到的結果相同的結果:


def solution(A):

    lst = []

    d = dict.fromkeys(set(A), lst)

    for i in range(len(A)):

        lst.append(i)

    print(d)

除了提供的其他答案外,您還可以使用字典理解路線:


def solution(A):

    d = { key : [] for key in A }

    for i in range(len(A)):

        d[A[i]].append(i)

    print(d)


查看完整回答
反對 回復 2022-11-01
  • 3 回答
  • 0 關注
  • 153 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號