迭代和递归(Python)--乘方、最大公约数、汉诺塔、斐波那契、回文字符串

本文主要是介绍迭代和递归(Python)--乘方、最大公约数、汉诺塔、斐波那契、回文字符串,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.迭代

def iterPower(base,exp):result=1.0while exp>0:result*=baseexp-=1return result

运行结果:


2.递归的乘法运算:

def recurMul(a,b):if b==1:return aelse:return a+recurMul(a,b-1)

运行结果:


3.递归乘方:


def recurPowerNew(base,exp):if exp==0:return 1elif exp>0 and exp%2==0:return recurPowerNew(base*base,exp/2)else:return base*recurPowerNew(base,exp-1)

运行结果:


4.最大公约数:

迭代法:

def gcdIter(a,b):r=1while r!=0:r=a%ba=bb=r  return a

运行结果:


递归:

def gcdRecur(a,b):if b==0:return aelse:return gcdRecur(b,a%b)

运行结果:


5.汉诺塔:

def printMove(fr, to):print('move from ' + str(fr) + ' to ' + str(to))def Towers(n, fr, to, spare):if n == 1:printMove(fr, to)else:Towers(n-1, fr, spare, to)Towers(1, fr, to, spare)Towers(n-1, spare, to, fr)

运行结果:


6.斐波那契数

def fib(x):"""assumes x an int >= 0returns Fibonacci of x"""assert type(x) == int and x >= 0if x == 0 or x == 1:return 1else:return fib(x-1) + fib(x-2)

运行结果:


7.回文字符串:

def isPalindrome(s):def toChars(s):s = s.lower()ans = ''for c in s:if c in 'abcdefghijklmnopqrstuvwxyz':ans = ans + creturn ansdef isPal(s):if len(s) <= 1:return Trueelse:return s[0] == s[-1] and isPal(s[1:-1])return isPal(toChars(s))

运行结果:





来自MIT的MOOC课件

这篇关于迭代和递归(Python)--乘方、最大公约数、汉诺塔、斐波那契、回文字符串的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1126707

相关文章

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

利用Python编写一个简单的聊天机器人

《利用Python编写一个简单的聊天机器人》这篇文章主要为大家详细介绍了如何利用Python编写一个简单的聊天机器人,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 使用 python 编写一个简单的聊天机器人可以从最基础的逻辑开始,然后逐步加入更复杂的功能。这里我们将先实现一个简单的

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭

Python实现高效地读写大型文件

《Python实现高效地读写大型文件》Python如何读写的是大型文件,有没有什么方法来提高效率呢,这篇文章就来和大家聊聊如何在Python中高效地读写大型文件,需要的可以了解下... 目录一、逐行读取大型文件二、分块读取大型文件三、使用 mmap 模块进行内存映射文件操作(适用于大文件)四、使用 pand

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一

Python xmltodict实现简化XML数据处理

《Pythonxmltodict实现简化XML数据处理》Python社区为提供了xmltodict库,它专为简化XML与Python数据结构的转换而设计,本文主要来为大家介绍一下如何使用xmltod... 目录一、引言二、XMLtodict介绍设计理念适用场景三、功能参数与属性1、parse函数2、unpa

Python中使用defaultdict和Counter的方法

《Python中使用defaultdict和Counter的方法》本文深入探讨了Python中的两个强大工具——defaultdict和Counter,并详细介绍了它们的工作原理、应用场景以及在实际编... 目录引言defaultdict的深入应用什么是defaultdictdefaultdict的工作原理

Python中@classmethod和@staticmethod的区别

《Python中@classmethod和@staticmethod的区别》本文主要介绍了Python中@classmethod和@staticmethod的区别,文中通过示例代码介绍的非常详细,对大... 目录1.@classmethod2.@staticmethod3.例子1.@classmethod