2-5 如何快速找到多個(gè)字典中的公共鍵

足球聯(lián)賽,對(duì)每一輪進(jìn)球球員進(jìn)行統(tǒng)計(jì),計(jì)算每一輪都有進(jìn)球的球員。

from functools import reduce
from random import randint, sample
import timeit

sample("abcdefg", randint(3, 6))  # 隨機(jī)取樣三到六個(gè)

s1 = {x: randint(1, 4) for x in sample("abcdefg", randint(3, 6))}

s2 = {x: randint(1, 4) for x in sample("abcdefg", randint(3, 6))}

s3 = {x: randint(1, 4) for x in sample("abcdefg", randint(3, 6))}


def get_for():
    res = []
    for key1 in s1:
        for key2 in s2:
            if key1 == key2:
                res.append(key1)
    return res


def get_common():
    return s1.keys() & s2.keys()


if __name__ == "__main__":
    print(s1, s2, s3)

    # 以下兩種方法功能基本相同
    print(get_for())
    print(s1.keys() & s2.keys())
    print(timeit.timeit(get_for))
    print(timeit.timeit(get_common))  # 此方法時(shí)間明顯低與迭代。
    # 多個(gè)字典的公共鍵
    print(reduce(lambda a, b: a & b, map(dict.keys, [s1, s2, s3])))
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀(guān)點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

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

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