QT 递归学习

递归就是自己调用自己,如果不给条件就会一直调用下去,会造成死循环。
最简的的例子

void MainWindow::print(int n)
{
    if(n==0)
    {
        return ;
    }
    qDebug()<<n;//重复逻辑
    print(n-1);//自己调用自己
}

看看递归执行顺序。
第一次n=1 执行fun(n+1),自己调用自己然后又从第一行开始执行,n=1,&n生成一个虚拟地址
第二次 n=2 执行fun(n+1),自己调用自己然后又从第一行开始执行,n=3,&n生成一个虚拟地址
第三次 n=3 n<3 不执行fun(n+1)
然后再执行下面的语句,因为n还是保存的上一次的地址,打印的还是n=3,感觉这里有点像链表,下一次找到3后面的地址,打印2.下一次找到的是1后面的地址,然后打印的是1,然后就执行完了。后面的我也没怎么搞懂。麻烦有高人指点

void MainWindow::fun(int n)
{
    qDebug()<<"1th   n:"<<n<<"&n:"<<&n;
    if(n<3)
    {
        fun(n+1);
    }
    qDebug()<<"2th   n:"<<n<<"&n:"<<&n;
}

阶乘的例子:

int MainWindow::jiecheng(int n)
{
    if(n==1)
    {
        return 1;
    }
    return  n* jiecheng(n-1);//自己调用自己
}

斐波那契数列的例子,求第几个的值:

int MainWindow::feibo(int n)
{
    if(n<3)//最简的的问题
    {
        return 1;
    }
    return feibo(n-1)+feibo(n-2);
}

调用

    print(5);
    qDebug()<<"斐波那契的第六个值为"<<feibo(6);
    qDebug()<<"阶乘5的值为:"<<jiecheng(5);
    fun(1);

在这里插入图片描述

参考:
https://blog.csdn.net/qq_40913465/article/details/110521154

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值