回溯算法的奥秘(LeetCode),组合77题、216题、40题
admin
2024-03-23 00:18:38
0

疫情如潮水,顺势而来、又逆势而去。反反复复,希望疫情快点消失——

回溯是递归的伴生产物,在前面的二叉树遍历中,我们发现,后续遍历就有一个回溯的思想。现在我们来仔细的学习这个算法思想。

回溯算法结合着递归使用,主要确定三个点:

  1. 返回值,绝大多数情况是void。
  2. 结束条件,在题目中其实它就已经高数你了结束条件,隐式的。
  3. 参数,这个一下子式确定不了的,边写边填。

  首先77题:指定区间,指定每个子集的个数。

定义一个集合用来存储子集。再定义一个子集集合存储元素。首先结束条件当让是子集长度等于k了。然后加入到ans里面。for循环用来确定递归的宽度。

class Solution {List> ans = new ArrayList<>();List list = new ArrayList<>();public List> combine(int n, int k) {dfs(k, n, 1);return ans;}private void dfs(int k, int n, int p) {if (list.size() == k) {ans.add(new ArrayList<>(list));return;}for (int i = p; i <= n; i++) {list.add(i);dfs(k, n, i + 1);list.remove(list.size() - 1);}}
}

递归函数后面接上回溯,也就是下一次循环初始化。

216题多了一个条件,子集元素相加等于指定tar.

所以在结束的时候多一个判断,回溯的时候多一个回溯:

class Solution {List> ans = new ArrayList<>();List list = new ArrayList<>();int sum = 0;public List> combinationSum3(int k, int n) {dfs(k, n, 1);return ans;}private void dfs(int k, int tar, int p) {if (list.size() == k) {if (sum == tar) {ans.add(new ArrayList<>(list));return;}}for (int i = p; i <=9; i++) {if (sum+i> tar || list.size() > k) {break;}sum += i;list.add(i);dfs(k, tar, i + 1);sum -= i;list.remove(list.size() - 1);}}
}

当子集长度大于k的时候,不满住题目

当子集sum大于tar的时候,也不满足

所以这里可以剪枝一下哦~

40题就难度提升了很多,题目给定数组,并且元素不能重复使用,也就是说我们还得在递归中判断当前的元素前面的父类递归有没有使用过,这就吧难度提升了很多。

这题的思路是这样的:

  1. 首先我们得解决重复使用这个大问题,元素是否重复使用,肯定是两个相同的元素做判断,所以我们得排序一下,方便判断是否元素相同也就是arr[i]==arr[i-1]。
  2. 其次就是既然元素相同的,如何知道它是这个数组中本来就有的元素呢,
  3. 如:【1,1,1,2】,所以这里使用一个数组,专门记录当前元素的下标是否被使用。
  List> ans = new ArrayList<>();public List> combinationSum2(int[] candidates, int target) {chak = new boolean[candidates.length];Arrays.sort(candidates);dfs(target, candidates.length, candidates, 0);return ans;}List list = new ArrayList<>();int sum = 0;boolean[] chak;private void dfs(int k, int n, int[] arr, int p) {if (sum == k) {ans.add(new ArrayList<>(list));return;}for (int i = p; i < n; i++) {if (sum + arr[i] > k) {break;}if (i > 0 && arr[i] == arr[i - 1] && !chak[i - 1]) {continue;}chak[i] = true;sum += arr[i];list.add(arr[i]);dfs(k, n, arr, i + 1);chak[i] = false;sum -= arr[i];list.remove(list.size() - 1);}}

 此时我们的回溯就有三个了:子集集合、子集的和、还有就是元素是否被使用的数组。

相关内容

热门资讯

贷款也“拼团” 银行抢单忙 购物能“拼团”,贷款也能! 近日,一场“拼团融资”的银企对接活动在省工业和信息化厅拉开帷幕。 “贷款...
逛花展、赶市集、嗨直播!202... 5月23日 “2026北京直播电商购物月” 在丰台区丽泽金融商务区·2026北京国际花展 正式拉开帷...
2026中关村毕业季|AI“吃... “上帝会掷骰子吗?” 在联想未来中心的“与智者同场”展区,一位海淀学子对着屏幕问道。 爱因斯坦微微前...
原创 今... 今日为5月23日,国际现货黄金价格在4500美元/盎司整数关口附近徘徊不前,日内最低触及4480美元...
三连亏后变为“无主”状态,农尚... 从吴亮手中接盘农尚环境(300536)不足三年后,林峰如今让出了公司控制权,上市公司进入“无主”状态...
55岁湖南女首富出手!豪掷13... 快科技5月24日消息,与马斯克、库克并肩而坐,刚参加完国宴的湖南女首富周群飞就买了家上市企业。 近日...
外资加仓A股,岂是跟风这么简单... 熬过忙碌的交易日,在周末安静时段,理清接下来布局方向。本篇为大家准备了5条要闻,涵盖市场动态、行业变...
原创 俄... 在全球能源的残酷牌桌上,手里攥着石油,腰杆子才能硬气。长期以来,中东的沙漠、俄罗斯的冰原、美国的页岩...
喜力啤酒有产品将涨价,华润啤酒... 来源:红星新闻 红星资本局5月22日消息,今日,红星资本局从雪花啤酒(厦门)有限公司、华润啤酒方面获...
原创 金... 心理预期调整刻不容缓,五月二十二日,黄金价格或将重现十五年前的历史性低迷。 近期若您密切关注着黄金市...
原创 马... 埃隆·马斯克如果能让SpaceX实现“科幻小说”级别的目标,他可能获得1万亿美元的收入。 埃隆·马斯...
涨涨涨!放开限制、可加杠杆!这... 韩国股市站在风口上! 据最新消息,为吸引更多海外资金进入股市,韩国政府计划放开限制,允许境外投资者直...
下周9家上会丨科创板首单IPO... IPO及再融资上会预告 据交易所官网审核动态信息,下周(5.25-5.29)IPO上会审核6家企业,...
富途、老虎市值蒸发1/4!或被... 来源:金融时报 5月22日,中国证监会宣布依法对Tiger Brokers (NZ) Limited...
马爸爸的好兄弟钱多多搞了杀猪盘... *此图由AI生成 作者| 史大郎&猫哥 来源| 是史大郎&大猫财经Pro 上周四,港股经纬天地大崩盘...
原创 壳... 编辑:XL 国际能源圈最近炸开了锅,壳牌这家百年石油巨头在2026年3月与委内瑞拉政府正式签署多项油...
存储热潮愈演愈烈!奖金拿到手软... 财联社5月24日讯(编辑 卞纯)在席卷全球的存储芯片热潮中,韩国“存储芯片双雄”SK海力士和三星无疑...
揽牌、合作、生态,跨境支付头部... 近日,国内头部跨境支付机构密集落地海外重要布局,一方面,连连数字、PingPong两家公司相继在中东...
原创 帮... 老铁们,周末好!我是帮主郑重。刚扫了一眼下周的财经日历,好家伙,事件一个接一个,堪称“消息面轰炸周”...
海南省住建厅与中国石化海南石油... 5月22日,中国石化海南石油分公司代表、党委书记李新强、总经理蔡文东一行赴海南省住建厅拜访交流。省住...