| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> python数据结构——(4)递归及其应用 -> 正文阅读 |
|
[数据结构与算法]python数据结构——(4)递归及其应用 |
递归概念递归(recursion):就是将问题分解为规模更小的相同的问题。 特征:在算法流程中调用自身,不用for、while循环。 举个简单的例子,计算 1+3+5+7+9。
用代码表示如下:
递归算法三定律:(必须同时成立才能调用递归算法)
递归应用应用一:进制转换 问题描述:将一个十进制数转换成任意进制。 十进制转换成二进制,我们可以用“栈”来实现。具体参考:pthon数据结构——(1)栈及其应用 这里我们用递归的方法实现。
在这里,我们假设转换的最高进制为16进制,实现代码如下:
测试代码:
结果:(计算器亲测没问题)
应用二:汉诺塔
思路:(从A,经过B, 移动到C)
基本结束条件:一个盘子的移动问题。 实现代码如下:
测试代码:(以3个为例)
结果:
我们总结出,N个盘子,最后的移动次数为:(2^N) - 1。 (这个问题据说是西方的一个故事,据说谁能将N=64的汉诺塔移动成功,世界末日就会来临。以每秒移动一次来计算,太阳的生命结束,也不可能移动成功,所以世界末日可不会来临)
|
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/25 16:45:57- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |