python利用遞歸方法實現(xiàn)求集合的冪集
什么是集合的冪集?
就是原集合中所有的子集(bai包括全集du和空集)構成的集族??蓴?shù)集是zhi最小的無限集; 它的冪集和實數(shù)dao集一一對應(也稱同勢),是不可數(shù)集。
不是所有不可數(shù)集都和實數(shù)集等勢,集合的勢可以無限的大。如實數(shù)集的冪集也是不可數(shù)集,但它的勢比實數(shù)集大。 設X是一個有限集,|X| = k,則X的冪集的勢為2的k次方。
代碼
def powSet(S):
#創(chuàng)建列表a存儲S中的元素
a=[]
for i in S:
a.append(i)
#判斷S中是否只有一個元素,作為遞歸的終點
if len(a)==1:
return set([frozenset(),frozenset(a)])
powset=set()
#遍歷S中的每一個元素
for i in range(len(a)):
S.remove(a[i])
temp = set()
#取S中的這一個元素去掉,得到集合S的下一層(相當于S-1),認為S-1冪集已知。
#將去掉的元素與S-1冪集中每一個元素都求并,得到新集合temp,temp和S-1的冪集求并便得到S的冪集
for j in powSet(S):
temp.add(j.union({a[i]}))
powset = powSet(S).union(temp)
S.add(a[i])
return powset
#驗證
s=set([1,2,3])
print(powSet(s))
#結果
{{frozenset({2}), frozenset({2, 3}), frozenset({1, 2}), frozenset({1, 2, 3}), frozenset({3}), frozenset({1}), frozenset(), frozenset({1, 3})}}
需要知識
冪集的概念
python set 和 frozenset 數(shù)據(jù)類型
心得體會
筆者在寫代碼時遇到的問題是認為powSet(S-1)(S-1代表S中去掉任一個元素)就完完全全地替代了真正去掉那一個隨機元素的元素組成的冪集。
實際上這樣是不完全的,因為設置的遞歸規(guī)則有缺陷,不可能完全遍歷所有情況。
解決:借助于集合元素的不可重復添加這一特性,我們可以遍歷遍歷所有S中的元素,都讓它們進行一次遞歸操作,這樣做雖然會產(chǎn)生n(S)次重復,但是它可以考慮到所有情況。
到此這篇關于python利用遞歸方法實現(xiàn)求集合的冪集的文章就介紹到這了,更多相關python遞歸方法求集合的冪集內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
淺談python 四種數(shù)值類型(int,long,float,complex)
下面小編就為大家?guī)硪黄獪\談python 四種數(shù)值類型(int,long,float,complex)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-06-06
Python鏈式調(diào)用數(shù)據(jù)處理實際應用實例探究
本文將深入介紹Python鏈式調(diào)用的概念、原理以及實際應用,通過豐富的示例代碼,幫助讀者更全面地理解和應用這一編程技巧2024-01-01
python+selenium爬取微博熱搜存入Mysql的實現(xiàn)方法
這篇文章主要介紹了python+selenium爬取微博熱搜存入Mysql的實現(xiàn)方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-01-01
Python中魔法參數(shù)?*args?和?**kwargs使用詳細講解
這篇文章主要介紹了Python中魔法參數(shù)?*args?和?**kwargs使用的相關資料,*args和**kwargs是Python中實現(xiàn)函數(shù)參數(shù)可變性的重要工具,分別用于接受任意數(shù)量的位置參數(shù)和關鍵字參數(shù),文中通過代碼介紹的非常詳細,需要的朋友可以參考下2024-12-12

