博客
关于我
leetcode 40 组合总和2 js
阅读量:668 次
发布时间:2019-03-15

本文共 1172 字,大约阅读时间需要 3 分钟。

要解决这个问题,我们可以使用回溯法来找出所有可以组成目标数的组合。以下是详细的解决方案:

方法思路

  • 排序数组:首先对候选数组进行排序,这样可以确保我们每次选择的是有序的元素,避免重复选择相同的元素。
  • 递归函数设计:使用一个递归函数进行深度优先搜索,参数包括当前和、起始索引和临时数组。
  • 剪枝条件:如果当前和超过目标数,直接返回,避免不必要的递归调用。
  • 重复元素处理:在递归过程中,确保不重复选择相同的元素,特别是在数组中有连续的相同元素时。
  • 结果记录:当和等于目标数时,将当前组合添加到结果集中。
  • 解决代码

    combinationSum2 = function (candidates, target) {
    candidates.sort((a, b) => a - b);
    const res = [];
    const dfs = (sum, start, temp) => {
    if (sum === target) {
    res.push(temp.slice());
    return;
    }
    if (sum > target) {
    return;
    }
    for (let i = start; i < candidates.length; i++) {
    if (i > start && candidates[i] === candidates[i - 1]) {
    continue;
    }
    temp.push(candidates[i]);
    dfs(sum + candidates[i], i + 1, temp);
    temp.pop();
    }
    };
    dfs(0, 0, []);
    return res;
    };

    代码解释

  • 排序数组:使用sort方法对候选数组进行排序。
  • 递归函数:定义了一个递归函数dfs,参数包括当前和sum、起始索引start和临时数组temp。
  • 递归条件:如果当前和等于目标数,添加组合到结果数组;如果当前和超过目标数,返回。
  • 遍历元素:从起始索引开始遍历数组中的每个元素。
  • 重复元素处理:如果当前元素与前一个元素相同,跳过以避免重复选择。
  • 递归调用:将当前元素加入临时数组,并递归调用函数。
  • 撤销操作:返回时从临时数组中移除元素,确保每次递归都有独立的组合路径。
  • 通过这种方法,我们可以高效地找到所有符合条件的组合,确保每个组合都是唯一的并且满足条件。

    转载地址:http://nhqmz.baihongyu.com/

    你可能感兴趣的文章
    Nginx 负载均衡与权重配置解析
    查看>>
    Nginx 负载均衡详解
    查看>>
    nginx 配置 单页面应用的解决方案
    查看>>
    nginx 配置https(一)—— 自签名证书
    查看>>
    nginx 配置~~~本身就是一个静态资源的服务器
    查看>>
    Nginx 配置清单(一篇够用)
    查看>>
    Nginx 配置解析:从基础到高级应用指南
    查看>>
    nginx+php的搭建
    查看>>
    nginx+tomcat+memcached
    查看>>
    nginx+Tomcat性能监控
    查看>>
    nginx+uwsgi+django
    查看>>
    Nginx-http-flv-module流媒体服务器搭建+模拟推流+flv.js在前端html和Vue中播放HTTP-FLV视频流
    查看>>
    nginx-vts + prometheus 监控nginx
    查看>>
    Nginx下配置codeigniter框架方法
    查看>>
    Nginx之二:nginx.conf简单配置(参数详解)
    查看>>
    Nginx代理websocket配置(解决websocket异常断开连接tcp连接不断问题)
    查看>>
    Nginx代理初探
    查看>>
    nginx代理地图服务--离线部署地图服务(地图数据篇.4)
    查看>>
    Nginx代理外网映射
    查看>>
    Nginx代理模式下 log-format 获取客户端真实IP
    查看>>