Aries之递归算法实际应用

在调用一个函数的过程中又出现直接或间接地调用该函数本身,成为函数的递归调用.
递归的两个条件:
1.函数自己调用自己;
2.必须有个明确地返回值.
说明: 函数每次调用,都会分配新的存储空间.
例一:
有5个人坐在一起,问第5个人多少岁?他说比第4个人大2岁。问第四个人岁数,他说比第三个人大2岁,以此类推,最后问第一个人,他说是10岁。请问第5个人多大?

-(NSUInteger)computeAgeWithNumber:(NSUInteger)num {
    if (num == 1) return 10;
    return [self computeAgeWithNumber:num-1] + 2;
}
- (void)viewDidLoad{
    [super viewDidLoad];
    NSUInteger result=[self computeAgeWithNumber:5];
    NSLog(@"result=%ld",result);
}

例二:
一列数的规则如下: 1、1、2、3、5、8、13、21、34、......求第30位是多少,用递归算法实现。

-(NSUInteger)computeCountwithNumber:(NSUInteger)num{
    if (num <= 2) return 1;
    return [self computeCountwithNumber:num-1] + [self computeCountwithNumber:num-2];      
}
- (void)viewDidLoad{
    [super viewDidLoad];
    NSUInteger result=[self computeCountwithNumber:30];
    NSLog(@"result=%ld",result);
}

例三:
利用递归实现n的阶乘的计算

-(NSUInteger)computeFactorialWithNumber:(NSUInteger)num {
    if (num == 0 || num == 1) return num;
    return [self computeFactorialWithNumber:num-1] * num;
}
- (void)viewDidLoad{
    [super viewDidLoad];
    NSUInteger result=[self computeFactorialWithNumber:5];
    NSLog(@"result=%ld",result);
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 第八章 递归(recursion) 8.1 导语 因为一些指导者倾向于先教递归作为第一个主要的控制结构,本章会以另...
    geoeee阅读 5,346评论 0 5
  • 1 递归的思想 以此类推是递归的基本思想。具体来讲就是把规模大的问题转化为规模小的相似的子问题来解决。在函数实现时...
    Bobby0322阅读 8,973评论 0 6
  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 8,906评论 0 4
  • 干干净净的郑爽 纯洁 乖巧 最可惜的是 在她人生最美好的年华 碰到了张翰这个渣渣 上帝给你关上了一扇窗 就会为你打...
    一叶茶阅读 2,593评论 2 1
  • 2010-05-15 23:45:23 下午,没课,打开电脑,又关掉,不知道该做些什么,其实也没什么可做的,一个人...
    郭薇薇阅读 1,526评论 0 0

友情链接更多精彩内容