当前位置: 首页 > news >正文

leetcode40-组合总和II

leetcode 40
在这里插入图片描述

思路

在做本题之前可以参考之前的文章:组合总和和组合总和III
本题的关键点是:每个元素只能使用一次,另外本题给的数组是无序的,并且元素之间可能存在重复项,举个例子,candidates = [1,2,1,1],这种可能性存在,所以本题的关键在于去重
假设candidates = [1,2,1,1], target = 3 可能的情况是:[1,2], [1,1,1]
也就是说元素每个元素1都是一个单独的元素,这里三个1可以组合成一个满足条件的答案,但是[1,2]这个组合最终只能有一个,我们可能看到这个题的时候最开始的想法是想通过普通的组合总和的方式拿到所有结果以后再去重,但是最后来进行去重工作量大,并且不容易通过leetcode的时间校验,所以最好的方式是在遇到重复的时候就进行排除
我们首先对其进行排序,排序后得到的结果[1,1,1,2]
然后我们先从第一个元素1开始拿到值以后放入path中,加入后续的元素形成组合,当遇到path = [1,1,1]的时候说明拿到了结果放入result中,后续通过回溯pop之后path = [1]再把2加入,得到path = [1,2]满足条件,放入result中此时第一层i = 0的元素已经与后续元素都组合完成,现在要更新startIndex = 1,遍历第二层i = 1,但是我们发现这个元素仍然为11和后续元素的所有可能形成的组合在前一个元素那里已经组合过一次了,所以需要去重。于是我们判断当candidates[i] === candidates[i-1]时,也就是下一个元素等于上一个元素的时候,我们要跳过,但是如果这样写的话只要遇到相同元素都会跳过,此时就会把[1,1,1]这个答案排除在外,所以需要再加上一个条件,只有当层级遍历中的下一个元素和上一层的元素相等的时候,才跳过,所以需要i > startIndex

这里如果想不通的话可以用vscode的debugger模式调试一下,看看每一步的过程是什么时候进行跳过的

实现

var combinationSum2 = function (candidates, target) {
    // 排序-从小到大
    candidates = candidates.sort((a, b) => a - b);
    let result = [], path = [], sum = 0;
    const backtracking = (candidates, target, startIndex) => {
        if (sum === target) {
            result.push([...path])
            return
        }
        if (sum > target) return
        for (let i = startIndex; i < candidates.length; i++) {
            // 新的一层中存在和上一层元素相同,需要去重
            if(i > startIndex && candidates[i] === candidates[i-1]) continue;
            path.push(candidates[i])
            sum += candidates[i]
            backtracking(candidates,target,i+1)
            sum -= path.pop()
        }
    }
    backtracking(candidates, target, 0)
    return result
};

相关文章:

  • Linux下的socket演示程序3(udp)
  • C++调用Openssl 报OPENSSL_Uplink(503EE220,08): no OPENSSL_Applink
  • CentOS 8 Stream 配置在线yum源参考 —— 筑梦之路
  • 力扣DAY30 | 热100 | 两两交换链表中的节点
  • LeetCode hot 100 每日一题(17)——160.相交链表
  • 算法--动态规划
  • 给聊天机器人装“短期记忆“:Flask版实现指南
  • Dubbo(18)Dubbo的SPI机制是什么?
  • Rocky linux部署DNS服务
  • GPU服务器集群网络规划方案
  • 阿里云数据学习20250327
  • 面试八股文--框架篇(SSM)
  • Nginx RTMP MP4 模块分析
  • 【9】Strongswan collections —— enumerator
  • C# 操作html下的css样式
  • 数制——FPGA
  • 【2025】基于springboot+vue的自习室管理系统的设计与实现(源码、万字文档、图文修改、调试答疑)
  • notepad++代码查看器分享
  • Qt 日志输出(重定向)
  • Android 底部EditView输入时悬浮到软键盘上方
  • 班组安全建设 网站/优化最狠的手机优化软件
  • 建设部网站首页督办案件/郑州seo培训
  • 西安专业网站建设/万网域名续费
  • 成都网站建设价格/搜索引擎优化教材答案
  • 辽宁建设工程信息网场内业绩/宁波seo基础入门
  • 网站建设网上售票系统/福建seo顾问