三个例题说明白什么是回溯算法,javascript解决组合问题
创始人
2025-05-29 03:06:02
0

最近忙疯了呜呜呜,读研不易,小李叹气…
今天好不容易忙的差不多了,刷了一会力扣,最近在刷回溯算法,刷着刷着还是觉得有点难,总结一波~

什么是回溯算法

回溯算法其实很复杂,本质上就是一种穷举的方式,穷举所有可能的结果,然后选出我们想要的答案。

怎么理解呢,其实我们一般在组合数中用回溯算法比较多,比如,从N个数里面按照一定的规则找出k个数的集合,这种问题我们就可以用到回溯算法。

具体怎么用呢?我们在解决组合问题的时候,往往会构造一棵树,然后一层层去遍历,回溯算法就是在集合中递归查找子集,集合的大小就是树的宽度,子集的大小就是数的深度

看到这里可能还是有点懵┭┮﹏┭┮,下面通过案例来讲解:

案例1:力扣第77题.组合

题目是这样的:
在这里插入图片描述

其实这个题就是一个典型的组合问题,从n个数中抽取k个数,组成集合,只不过我们要列举出来所有的集合情况,“列举所有的情况”,遇到这种,一般肯定就是穷举,用for循环肯定也能解决,但是如果n和k的值一旦变得很大,for循环就很冗余和复杂,所以这里最好学会使用回溯。

根据上面介绍的,回溯法就是构建一棵树,宽度为n,深度为k,这里假设n为4,k为2,就可以画出树形结构如下所示:
在这里插入图片描述
其实这个图就很清晰明了啦,其实问题就转换成,树的遍历问题,把从root节点到最后的子节点的所有路径都写出来,现在关键是怎么写代码,先把正确的代码摆出来:

/*** @param {number} n* @param {number} k* @return {number[][]}*/
var combine = function(n, k) {var result=[];//这个定义了全局变量,用来保存最终结果的var path=[];//这个定义了全局变量,用来保存树的每一条路径var temp=[]//这里注意坑,这里我采用一个中间变量来承接path的内容,不然直接=赋值的就是数组的地址,可以敲代码验证一下//----------------这个函数就是定义的的递归函数————————————————var backtracking=function(n,k,index){if(path.length==k){//定义递归跳出的最终条件for(var i=0;itemp.push(path[i]);} result.push(temp)  temp=[]  return;}for(var i=index;i<=n;i++){//控制树的横向遍历path.push(i);//处理节点backtracking(n,k,i+1);//控制树的纵向遍历path.pop();//回溯,撤销处理的节点}}backtracking(n,k,1);return result;
};

具体的写在注释里面啦,建议多看几遍代码结构,后面好几个题都要这样写~

看懂上面这个题之后,下面通过几个题目练练手,也是用到了回溯算法,看看能否举一反三:

案例2:力扣216.组合总和III

在这里插入图片描述
画图是这样的(这里举k=2,n=4的例子):
在这里插入图片描述
其实这个题本质上和上一个题差不多,就是从9个数中选出k个数的集合,上一题中递归结束的条件是path数组的长度等于k,这里结束的条件稍微发生了变化,首先path数组的长度也要等于k,其次,这k个数的和应该等于n。想到这里,其实就很容易照着上面写出代码:

/*** @param {number} n* @param {number} k* @return {number[][]}*/
var combine = function(n, k) {var result=[];var path=[];var temp=[];//更改点1var sum=0;var backtracking=function(n,k,index){if(path.length==k){if(sum==n){//更改点2for(var i=0;itemp.push(path[i]);} result.push(temp)  temp=[] } return;}for(var i=index;i<=9;i++){//更改点3path.push(i);sum=sum+i;//更改点4backtracking(n,k,i+1);path.pop();sum=sum-i;//更改点5}}backtracking(n,k,1);return result;
};

这样问题就完美的解决了~下面我们继续加大点难度,这次我们尝试不要复制上面的代码,尝试自己去手敲:

案例3:力扣17.电话号码的字母组合

在这里插入图片描述
其实这个题还是和之前的问题一样,只是现在这个n不确定,n=digits.length*3,digits.length对应的就是输入的数字的个数,每个数字除了01,都代表三个字母。k等于digits.length。所以我们可以考虑用一个数组来保存每个数字对应的字母:

/*** @param {string} digits* @return {string[]}*/
var letterCombinations = function(digits) {const letterMap=["","","abc","def","ghi","jkl","mno","pqrs","tuv","wxyz"];var result=[];var path=[];var temp=[];var backtracking=function(digits,index){if(path.length==digits.length){for(var i=0;itemp.push(path[i]);}result.push(temp.join(''));temp=[];return;}var digit=digits[index]-0;var letters=letterMap[digit];for( var j=0;jpath.push(letters[j]);backtracking(digits,index+1);path.pop();}}if(digits.length==0){return result;}backtracking(digits,0);return result;
};

这个题的区别在于,怎么把上一层和下一层区分开来,之前都是通过加1进行区分,现在是对字母进行遍历,还是有点难度的。

相关内容

热门资讯

企业IP打造指南:小公司低成本... 小公司做企业IP,不是为了装门面,而是让客户在没见到你之前,就能通过内容知道你是谁、你解决什么问题、...
官方:赵心童入选世界斯诺克名人... 北京时间5月8日消息,世界斯诺克巡回赛(WST)今日正式公布了2025/26赛季年终奖项及名人堂更新...
小灰熊AI学员王锋:希望能跟上... 35了,老程序员了。 从进入互联网行业到现在,其实已经做了很多年移动端开发。最早那几年,安卓行业发展...
原创 2... 2026年全国两会把稳定房地产市场列为重点工作,政府工作报告明确提出因城施策控增量、去库存、优供给。...
一年翻倍,六年未归——徽商银行... 文:向善财经 今年的港股市场,与A股市场出现了明显的分化。 A股这边,科技板块在AI浪潮中热闹非凡;...
古井贡酒2025:在行业深度调... 以“稳”为底、以“新”为翼。 文/每日财报 杜康 在行业库存高企、价格倒挂的背景下,当多数酒企在为...
好上好8408万收购鼎瑞芯加码... 5月7日晚,好上好(001298.SZ)抛出一份收购公告,拟以8408万元现金收购深圳市鼎瑞芯科技有...
全面大撤离!李嘉诚英国“套现”... 突发,李嘉诚又卖了。 这次,套现了455亿。 金额不少,但更值得关注的是透露着不同寻常的信号。 因为...
油气价格上涨加剧法国一季度贸易... 据新华社,法国海关7日发布的数据显示,受中东局势推高国际油气价格影响,法国今年第一季度贸易逆差扩大至...
昆仑芯启动科创板IPO上市辅导... 5月8日,据证监会官网显示,昆仑芯(北京)科技股份有限公司于2026年5月7日正式启动科创板上市辅导...
贵州茅台酒股份有限公司关于回购... 来源:上海证券报 证券代码:600519 证券简称:贵州茅台 公告编号:临2026-016 贵州茅...
百度昆仑芯启动科创板上市辅导,... 5月8日,证监会官网显示,昆仑芯(北京)科技股份有限公司 (下称“昆仑芯”)于2026年5月7日正式...
滕州信华的承压时刻:罚单、失信... 2026年4月末,滕州信华美元债单日跌近2%,关联方被列“老赖”。半年前,这家AA+城投曾因非市场化...
002808,或被终止上市! 【导读】因触及财务类退市指标,*ST恒久或被终止上市 中国基金报记者 李智 又一A股或被终止上市。 ...
院士团队掌舵,溧阳这家企业已完... 近日,溧阳天目先导电池材料科技有限公司(下称“天目先导”)官宣完成B轮融资,投资方包括知卓创新资本、...
工商银行全新推出“工盈研选”品... 深圳商报·读创客户端记者 詹钰叶 近日,工商银行重磅推出「工盈研选」基金销售服务品牌,以客户盈利为核...
和讯信息胡云龙:逼空走势,周五... 今天市场出现逼空走势,场内投资者因持有筹码而尤为受益。五一前布局的投资者当前收获颇丰。然而,随着上证...
今晚,油价上调! 4月21日国内成品油价格下调以来,国际市场原油价格剧烈震荡,前期大幅上涨后近日有所回落,本次调价的前...
南方东英旗下两倍做多海力士,成... 【导读】南方东英旗下两倍做多海力士,成为全球最大的个股杠杆及反向产品 中国基金报记者 伊万 人工智能...
原创 金... 黄金,这东西从古至今就没离开过中国人的生活。从老辈人压箱底的小黄鱼,到如今年轻人结婚绕不开的“三金”...