浅析递归算法的运行原理

本文详细解析了递归算法的运行原理,通过分组归并排序的例子阐述了递归的特点和执行流程。递归必须有终止条件,子过程规模逐渐缩小,所有子过程的解构成整体解。文章强调找出递归的入口、出口和终止点的重要性,并指出递归在很多算法中的应用。
摘要由CSDN通过智能技术生成

递归,即程序(函数)直接或者间接调用自己的一个过程。

递归算法主要有四个特点:

1. 必须有可达到的终止条件,不然程序(函数)将陷入死循环(死锁);

2. 子过程可通过再次递归的方式调用求解或因满足终止条件而直接求解;

3. 子过程的规模比原过程小(一般是折半),或更接近终止条件;

4. 所有子过程的解构成整个过程的解的集合。

先来一段代码:

下面是分组归并排序(分治法)的递归过程:
在Java环境下运行:

void Mergesort(int arr[],int s,int t) {
        int m,r1[]=
  • 6
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值