关于递归
来源:互联网 发布:暨南大学 知乎 编辑:程序博客网 时间:2024/05/18 13:28
简答的说,递归的数学模型其实就是归纳法。
归纳法适用于想解决一个问题转化为解决他的子问题,而他的子问题又变成子问题的子问题,而且我们发现这些问题其实都是一个模型,也就是说存在相同的逻辑归纳处理项。当然,递归结束的那一项处理方法不适用于我们的归纳处理项,否则我们就无穷递归了。这里又引出了一个归纳终结点以及直接求解的表达式。如果运用列表来形容归纳法就是:
步进表达式:问题蜕变成子问题的表达式
结束条件:什么时候可以不再是用步进表达式
直接求解表达式:在结束条件下能够直接计算返回值的表达式
逻辑归纳项:适用于一切非适用于结束条件的子问题的处理,当然上面的步进表达式其实就是包含在这里面了。
这样其实就结束了,递归也就出来了。
递归算法的一般形式:
void func( mode){
if(endCondition){
constExpression //基本项
}
else
{
accumrateExpreesion /归纳项
mode=expression//步进表达式
func(mode) //调用本身,递归
}
}
当函数被调用时,它的变量的空间是创建于运行时堆栈上的。以前调用的函数的变量仍保留在堆栈上,新调用的函数产生的变量将压入栈中,因此,当最后达到递归结束条件的时候,随着每层递归调用函数的结束,该层调用时产生的变量也将销毁,使其上一次调用产生的变量位于栈顶,接受处理。
一旦你理解了递归,阅读递归函数最容易的方法不是纠缠于它的执行过程,而是相信递归函数会顺利完成它的任务。如果你的每个步骤正确无误,你的限制条件设置正确,并且每次调用之后更接近限制条件,递归函数总是能正确的完成任务。
- 关于递归
- 关于递归
- 关于递归
- 关于递归
- 关于递归
- 关于递归
- 关于递归
- 关于递归
- 关于递归
- 关于递归
- 关于递归
- 关于递归
- 关于递归
- 关于递归
- 关于递归
- 关于递归
- 关于递归
- 关于尾递归【转】
- C/C++语言中参数的传值问题
- android:gravity / android:layout_Gravity,android:padding / android:layout_margin属性区分
- jquery 获取 GridView 或 Repeater 里边的 RadioButtonList 选中值
- 注册页面所涉及的知识
- 关于递归
- Winform DataGridView中利用WebClient异步加载显示网络地址的图片
- Blank Your Monitor + Easy Reading
- java异常(异常处理的陋习)
- 简明 Vim 练级攻略
- GridView的技巧 绑定行事件,取得单元格值,或取得单元格控件方法,鼠标经过样式
- 带权中位数
- 花费7800的linux培训教程-拯救硬盘10绝招(下)
- RSH(Really Simple History)记录ajax的浏览历史