Heim >Backend-Entwicklung >Python-Tutorial >Python-Implementierungsbeispiel zum Finden aller Teilmengen einer Menge

Python-Implementierungsbeispiel zum Finden aller Teilmengen einer Menge

不言
不言Original
2018-05-05 10:19:054234Durchsuche

Dieser Artikel stellt hauptsächlich das Beispiel der Python-Implementierung vor, um alle Teilmengen einer Menge zu finden. Jetzt kann ich es mit Ihnen teilen

Methode 1: Regressionsimplementierung

def PowerSetsRecursive(items):
  """Use recursive call to return all subsets of items, include empty set"""
  
  if len(items) == 0:
    #if the lsit is empty, return the empty list
    return [[]]
  
  subsets = []
  first_elt = items[0] #first element
  rest_list = items[1:]
  
  #Strategy:Get all subsets of rest_list; for each of those subsets, a full subset list
  #will contain both the original subset as well as a version of the sebset that contains the first_elt
  
  for partial_sebset in PowerSetsRecursive(rest_list):
    subsets.append(partial_sebset)
    next_subset = partial_sebset[:] +[first_elt]
    subsets.append(next_subset)
  return subsets

def PowerSetsRecursive2(items):
  # the power set of the empty set has one element, the empty set
  result = [[]]
  for x in items:
    result.extend([subset + [x] for subset in result])
  return result

Methode 2: Binäre Methode

def PowerSetsBinary(items): 
  #generate all combination of N items 
  N = len(items) 
  #enumerate the 2**N possible combinations 
  for i in range(2**N): 
    combo = [] 
    for j in range(N): 
      #test jth bit of integer i 
      if(i >> j ) % 2 == 1: 
        combo.append(items[j]) 
    yield combo

Verwandte Empfehlungen:

Python ermittelt, ob a set Eine Methode zum Implementieren einer einfachen Textzeichenfolgenverarbeitung in Python für die Teilmengenmethode einer anderen Sammlung

Das obige ist der detaillierte Inhalt vonPython-Implementierungsbeispiel zum Finden aller Teilmengen einer Menge. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn