洛谷P1464---Function,记忆化搜索基础典型例题

文章讨论了在递归过程中,通过记忆化技术存储之前计算结果以避免重复运算,特别是在遇到反复调用特定数递归的情况下。通过引入状态数组vis和arr,可以显著减少计算时间,提高效率。提供了一个实际应用的代码示例并展示了优化后的效果。
摘要由CSDN通过智能技术生成
  • 优势

在递归过程中,某个数的递归过程会涉及n次运算,而且这个数的递归过程可能会被反复调用,涉及n(o)次运算,容易超时。

但如果我们将某个数的递归出的结果记录下来,即将这个递归结果记忆化,到时候调用即可直接引用结果,不必再去执行递归的过程。

  • 适合的情况

递归过程+会反复调用某一个数的递归==可以将结果记忆化

即我们在递归的过程里加入了状态数组bool

**************************************************************************************************************

我们来看题来理解

题目已经说过,15时会调用很多次递归,那么可以记忆化处理

*vis数组表示状态,目的是检查某个数的递归结果是否已经存入arr数组

*arr储存数组,储存的是某个数的递归结果,方便以后直接引用结果而非再进入递归

最后,在main函数中返回func(a,b,c)的值即可

**************************************************************************************************************

代码奉上

结果 all AC

  • 7
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值