记忆化搜索

记忆化搜索

在递归过程中,有许多分支被反复计算,会大大降低算法的执行效率。用记忆搜索,讲已经计算出来的结果保存起来,以后需要用到直接去除结果,避免重复运算。

题目链接 数不清的数

原本的代码

外面一层t的while循环,里面再计算1-x的的二进制中1的和,时间复杂度是on的三次方,时间复杂度太大了。

看题目的数据范围,只有31个数字,可以讲1-31的全部计算出来保存到数组中去,下面while直接从数组中取数字即可,减少了一层的时间复杂度。

dp[i]就是以i结尾的二进制数字个数,题目需要求的是0-2的n次方

相关推荐
_Li.19 小时前
Simulink-螺旋桨动力模块
人工智能·算法·机器学习
Charlie_lll19 小时前
力扣解题-438. 找到字符串中所有字母异位词
后端·算法·leetcode
奶茶树19 小时前
【数据结构】红黑树
数据结构·c++·算法
AI周红伟19 小时前
周红伟:OpenAI 首席运营官,尚未真正看到人工智能渗透到企业业务流程中
人工智能·算法·性能优化
问好眼19 小时前
《算法竞赛进阶指南》0x01 位运算-2.增加模数
c++·算法·位运算·信息学奥赛
Full Stack Developme19 小时前
哈希是什么
算法·哈希算法
薛定e的猫咪19 小时前
【AAAI 2025】基于扩散模型的昂贵多目标贝叶斯优化
论文阅读·人工智能·算法
Fox爱分享19 小时前
拼多多面试: 设计“砍一刀”算法,怎么防止被刷破产?90% 的人死在了“最后 0.01 元”
后端·算法·面试
NGC_661119 小时前
归并排序算法
java·数据结构·算法
你撅嘴真丑19 小时前
第十章-训练参考
算法