望山居

真相本来是一体的,太大了,所以大家给他画了格子,结果把自己困了起来

导航

统计

递归详解

递归详解

在计算机科学领域, 递归是用于处理一类具有相同子问题处理方式的问题;
是数学归纳法, 数学递推公式在计算机中的应用

The power of recursion evidently lies in the possibility of defining an infinite set of objects by a finite statement. In the same manner, an infinite number of computations can be described by a finite recursive program, even if this program contains no explicit repetitions.
--- by Niklaus Wirth, Algorithms + Data Structures = Programs, 1976

用递归的方法来解决问题的关键, 在于准确找到子问题

递归的简单应用

1. 阶乘

计算 n!=n(n1)21

即令 f(n)=nf(n1)

void Recursion_Factorial(int n)
{
if(n == 1) return n;
return n * Recursion_Factorial(n-1);
}

2. 寻找所有子集

template<class T>
void Recursion_Subset(vector<T> dataSet, vector<vector<T>>& result)
{
if (dataSet.empty()) { result.push_back({}); }
else
{
T data = dataSet.back();
dataSet.pop_back();
Recursion_Subset(dataSet, result);
int size = result.size();
for (int i = 0; i < size; i++)
{
result.push_back(result[i]);
result.back().push_back(data);
}
}
return;
}

posted on   穆道  阅读(72)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示