算法笔记:递归(c++实现)

简介: 算法笔记:递归(c++实现)

递归定义

递归定义是一种直接或者间接引用自身的定义方法。

递归包括两部分:

   基础部分(直接形式列举)

   递归部分(给出方法)

斐波那契数列的递归定义

{ f0 = 0, f1 = 1

{f(n) = f(n-1)+f(n-2) n>1

递归算法

使用递归定义的算法

long Fib(long n)
 
{
 
  if(n<=1) return n;
 
  else return (Fib(n-2) +Fib(n-1));
 
}


递归的优点是简洁。缺点是耗时长
(尤其是在递归次数多的时候)。

(使用如下代码可以得到运行时间)

#include<ctime>
 
clock_t start_t, end_t;
 
start_t = clock();
 
.............
 
end_t = clock();
 
std::cout << "Spend " << (double)(end_t - start_t)/1000.0 << " s\n";

其他的一些递归例子:

问题1 :逆序输出正整数的各位数

设有正整数n = 12345,

输出各位数的逆序形式(54321)。


分析(使用递归):

1. 首先输出末位数

2. 然后输出剩下的逆序形式


c++实现:

void print_digit(unsigned n)
 
{
 
std::cout << n%10;    //1.输出末位数,使用求余(%),
 
if (n >= 10)  //递归条件,非常重要,是递归停止的条件。
 
print_digit(n / 10); //2. 输出剩下的数的逆序形式,使用/ 得到剩下的。
 
}
 

问题2: 汉诺塔问题

假设有3个塔座:x,y,z.

塔座x上有从小到大编号为1,2,...n的n个圆盘,

要求把x的圆盘全部搬到z上,且:1.每次只能移动一个圆盘。2.大的盘子不能放在小的盘子上。


分析:

1.把第n个盘子移动到z上(先把n-1个盘子移动到y上

2.把剩下的(n-1)盘子移动到z上

c++实现:

#include<iostream>
 
int count = 0;
//将第n个塔从a移动到b
void move_tower(int n, char a, char b)
{
  std::cout << n << ": "<<char(a) << "->" << char(b);
  std::cout<< "\n";
  count++;
}
 
//移动n个塔,从x移动倒z,以y为中间点
void hanio(int n, char x, char z, char y)
{
  if (n)
  {
    hanio(n - 1, x, y, z);
    move_tower(n, x, z);
    hanio(n - 1, y, z, x);
  }
}
 
int main()
{
  int active = 1;
  while (active)
  {
    count = 0;
    std::cout << "输入塔的层数: ";
    int n;
    std::cin >> n;
    if (n < 1)
    {
      std::cout<<"无效输入,即将退出\n";
      break;
    }
    hanio(n , 'x', 'z', 'y');
    std::cout << "用了" << count << "次\n";
  }
  system("pause");
  return 0;

问题3: 排列组合问题。

问题,设有n个自然数的集合,输出集合产生的各种排列(有序)。

如集合{0,1,2}的排列有

0,1,2; 0,2,1;

1,0,2; 1,2,0;

2,0,1; 2,1,0;

问题分析:可以分为两步

1.确定排列的开头

2.排剩下的集合


c++实现:

#include<iostream>
 
void perm(int a[], int k, int n)
{
  if (k == n-1)         //当k=n-1时,即已经排列完了,进行输出。
  {
    for (int i = 0;i < n; i++)
      std::cout << a[i] << " ";
    std::cout << "\n";
  }
  else
  {
    for (int i = k; i < n; i++)       
    {
      int t = a[k]; a[k] = a[i]; a[i] = t;  //排第k位
      perm(a, k+1, n);          //剩下的 从(k+1)开始排
      t = a[k]; a[k] = a[i]; a[i] = t;  //还原
    }
  }
}
int main()
{
  int  a[10] = { 0,1,2,3,4,5,6,7,8,9 };
  perm(a, 0, 6);
  system("pause");
  return 0;
}


相关文章
|
1月前
|
负载均衡 算法 安全
探秘:基于 C++ 的局域网电脑控制软件自适应指令分发算法
在现代企业信息化架构中,局域网电脑控制软件如同“指挥官”,通过自适应指令分发算法动态调整指令发送节奏与数据量,确保不同性能的终端设备高效运行。基于C++语言,利用套接字实现稳定连接和线程同步管理,结合实时状态反馈,优化指令分发策略,提升整体管控效率,保障网络稳定,助力数字化办公。
52 19
|
1月前
|
存储 算法 测试技术
【C++数据结构——树】二叉树的遍历算法(头歌教学实验平台习题) 【合集】
本任务旨在实现二叉树的遍历,包括先序、中序、后序和层次遍历。首先介绍了二叉树的基本概念与结构定义,并通过C++代码示例展示了如何定义二叉树节点及构建二叉树。接着详细讲解了四种遍历方法的递归实现逻辑,以及层次遍历中队列的应用。最后提供了测试用例和预期输出,确保代码正确性。通过这些内容,帮助读者理解并掌握二叉树遍历的核心思想与实现技巧。
49 2
|
2月前
|
存储 算法 安全
基于红黑树的局域网上网行为控制C++ 算法解析
在当今网络环境中,局域网上网行为控制对企业和学校至关重要。本文探讨了一种基于红黑树数据结构的高效算法,用于管理用户的上网行为,如IP地址、上网时长、访问网站类别和流量使用情况。通过红黑树的自平衡特性,确保了高效的查找、插入和删除操作。文中提供了C++代码示例,展示了如何实现该算法,并强调其在网络管理中的应用价值。
|
1月前
|
存储 算法 安全
基于哈希表的文件共享平台 C++ 算法实现与分析
在数字化时代,文件共享平台不可或缺。本文探讨哈希表在文件共享中的应用,包括原理、优势及C++实现。哈希表通过键值对快速访问文件元数据(如文件名、大小、位置等),查找时间复杂度为O(1),显著提升查找速度和用户体验。代码示例展示了文件上传和搜索功能,实际应用中需解决哈希冲突、动态扩容和线程安全等问题,以优化性能。
|
2月前
|
算法 安全 C++
用 C++ 算法控制员工上网的软件,关键逻辑是啥?来深度解读下
在企业信息化管理中,控制员工上网的软件成为保障网络秩序与提升办公效率的关键工具。该软件基于C++语言,融合红黑树、令牌桶和滑动窗口等算法,实现网址精准过滤、流量均衡分配及异常连接监测。通过高效的数据结构与算法设计,确保企业网络资源优化配置与安全防护升级,同时尊重员工权益,助力企业数字化发展。
65 4
|
3月前
|
算法 Python
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果;贪心算法在每一步选择局部最优解,追求全局最优;动态规划通过保存子问题的解,避免重复计算,确保全局最优。这三种算法各具特色,适用于不同类型的问题,合理选择能显著提升编程效率。
81 2
|
4月前
|
算法 API 计算机视觉
人脸识别笔记(一):通过yuface调包(参数量54K更快更小更准的算法) 来实现人脸识别
本文介绍了YuNet系列人脸检测算法的优化和使用,包括YuNet-s和YuNet-n,以及通过yuface库和onnx在不同场景下实现人脸检测的方法。
138 1
|
4月前
|
算法
❤️算法笔记❤️-(每日一刷-160、相交链表)
❤️算法笔记❤️-(每日一刷-160、相交链表)
33 1
|
4月前
|
JSON 算法 数据可视化
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
这篇文章是关于如何通过算法接口返回的目标检测结果来计算性能指标的笔记。它涵盖了任务描述、指标分析(包括TP、FP、FN、TN、精准率和召回率),接口处理,数据集处理,以及如何使用实用工具进行文件操作和数据可视化。文章还提供了一些Python代码示例,用于处理图像文件、转换数据格式以及计算目标检测的性能指标。
109 0
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
|
4月前
|
算法 数据处理 C++
c++ STL划分算法;partition()、partition_copy()、stable_partition()、partition_point()详解
这些算法是C++ STL中处理和组织数据的强大工具,能够高效地实现复杂的数据处理逻辑。理解它们的差异和应用场景,将有助于编写更加高效和清晰的C++代码。
89 0