Heim > Backend-Entwicklung > Python-Tutorial > Turm von Hanoi und Fibonacci-Sequenz in Python basierend auf einem rekursiven Algorithmus implementiert

Turm von Hanoi und Fibonacci-Sequenz in Python basierend auf einem rekursiven Algorithmus implementiert

不言
Freigeben: 2018-04-18 14:28:11
Original
2581 Leute haben es durchsucht

Dieser Artikel stellt hauptsächlich den Turm von Hanoi und die von Python basierende Fibonacci-Sequenz vor. Er analysiert die rekursiven Implementierungstechniken des Turms von Hanoi und der Fibonacci-Sequenz in Form von Beispielen dazu

Dieser Artikel beschreibt die in Python implementierten Tower of Hanoi- und Fibonacci-Sequenzen basierend auf rekursiven Algorithmen. Teilen Sie es als Referenz mit allen. Die Details lauten wie folgt:

Hier verwenden wir zwei Beispiele, um die Verwendung der Rekursion in Python zu erlernen.

1. Finden Sie die Zahl mit dem Index n in der Fibonacci-Folge (der Index zählt von 0)

Die Form der Fibonacci-Folge ist So: 0,1,1,2,3,5,8,13...

① Bei Verwendung der while-Schleife lautet der Python2-Code wie folgt:


def fib(n):
  a,b=0,1
  count=0
  while count<n:
    a,b=b,a+b
    count=count+1
  print a
Nach dem Login kopieren


Die laufenden Ergebnisse sind wie folgt:

>>> >0
> >> fib(1)
>>> fib(2)
>>> 🎜>2
> ;>> fib(4)
3
>>> fib(5)
5



② Rekursion verwenden (Rekursion muss Randbedingungen sein)

, der Python2-Code lautet wie folgt:


def fib(n):
  if n==0 or n==1:#递归的边界条件
    return n
  else:
    return fib(n-1)+fib(n-2)
Nach dem Login kopieren
Die laufenden Ergebnisse sind wie folgt:


>>> fib(0)

0

>>> fib(1)
1

>> ;> fib(2)
1
>>> fib(3)
>>> >> fib(5)
5


Rekursion ist einer der Algorithmen, der rechnerisches Denken am besten ausdrückt und uns den Ausführungsprozess der Rekursion ansieht :



Für dasselbe Programm ist die Ausführungseffizienz der Rekursion geringer als die der Schleife und der Systemressourcenverbrauch höher, obwohl das Programm einfach ist und die Rekursion verwendet der Schleife. Da die Rekursion Schicht für Schicht aufgerufen und nach Abschluss Schicht für Schicht zurückgegeben wird, ist die Ausführungseffizienz der Rekursion nicht hoch. Warum also Rekursion verwenden? Da es einige Probleme gibt, können wir keine sehr offensichtliche Schleifenlösung finden, aber es ist einfach, eine offensichtliche rekursive Lösung zu finden. Nehmen wir zum Beispiel das berühmte Turmproblem von Hanoi.

2. Tower of Hanoi

Das Bild unten ist eine vereinfachte Version des Tower of Hanoi-Spiels mit nur 4 Platten:

Die Regeln des Tower of Hanoi-Spiels lauten wie folgt:

Der Python2-Code lautet wie folgt:

Laufergebnis:

def hanoi(a,b,c,n):
  if n==1:#递归结束条件
    print a,&#39;->&#39;,c
  else:
    hanoi(a,c,b,n-1)
    print a,&#39;->&#39;,c
    hanoi(b,a,c,n-1)
Nach dem Login kopieren
>>> ','C',1)

A -> 🎜>A ->C
B ->>> >A -> B

A -> 🎜>


Verwandte Empfehlungen:


Python-Implementierung und -Anwendung des neuronalen Netzwerkalgorithmus (BP)




Das obige ist der detaillierte Inhalt vonTurm von Hanoi und Fibonacci-Sequenz in Python basierend auf einem rekursiven Algorithmus implementiert. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage