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

网站用nodejs做后台seo搜索引擎优化人才

网站用nodejs做后台,seo搜索引擎优化人才,有那个网站可以做任务赚钱,学动漫制作专业后悔吗文章目录 1. 问题概述2. 组合总和I(无重复元素,允许重复使用)2.1 方法思路2.2 代码实现2.3 复杂度分析 3. 组合总和II(包含重复元素,不可重复使用)3.1 方法思路3.2 代码实现3.3 关键点解析3.4 示例分析 4. …

文章目录

    • 1. 问题概述
    • 2. 组合总和I(无重复元素,允许重复使用)
      • 2.1 方法思路
      • 2.2 代码实现
      • 2.3 复杂度分析
    • 3. 组合总和II(包含重复元素,不可重复使用)
      • 3.1 方法思路
      • 3.2 代码实现
      • 3.3 关键点解析
      • 3.4 示例分析
    • 4. 总结对比
    • 5. 常见问题
      • Q1:为什么必须排序?
      • Q2:去重逻辑为何用`i > start`?

1. 问题概述

组合总和(Combination Sum)是经典的算法问题,常见于面试和编程练习。本文针对两个变体问题进行解析:

  • 问题39(组合总和I)
    给定无重复元素的整数数组candidates和目标数target,找出所有可以使数字和等于target唯一组合。数组中的数字可以无限次重复使用。

  • 问题40(组合总和II)
    给定可能包含重复元素的整数数组candidates和目标数target,找出所有可以使数字和等于target唯一组合。数组中的每个数字在每个组合中只能使用一次。

2. 组合总和I(无重复元素,允许重复使用)

2.1 方法思路

使用回溯算法遍历所有可能的组合,并通过排序剪枝优化效率:

  1. 排序预处理:对数组排序,便于后续剪枝。
  2. 回溯框架:递归遍历数组,允许重复选择同一元素。
  3. 剪枝优化:当当前路径和超过目标值时提前终止循环。

2.2 代码实现

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;class Solution {public List<List<Integer>> combinationSum(int[] candidates, int target) {List<List<Integer>> result = new ArrayList<>();Arrays.sort(candidates); // 排序以便剪枝backtrack(candidates, target, 0, new ArrayList<>(), 0, result);return result;}private void backtrack(int[] candidates, int target, int start, List<Integer> path, int sum, List<List<Integer>> result) {if (sum == target) {result.add(new ArrayList<>(path)); // 记录有效组合return;}for (int i = start; i < candidates.length; i++) {int num = candidates[i];if (sum + num > target) break; // 剪枝:后续元素更大,无需继续path.add(num);backtrack(candidates, target, i, path, sum + num, result); // 允许重复使用ipath.remove(path.size() - 1); // 回溯}}
}

2.3 复杂度分析

  • 时间复杂度:最坏情况为O(N^(T/M)),其中N为数组长度,T为目标值,M为最小元素值。剪枝优化后实际效率更高。
  • 空间复杂度:递归栈深度为O(T/M)

3. 组合总和II(包含重复元素,不可重复使用)

3.1 方法思路

在回溯基础上增加去重处理

  1. 排序预处理:使相同元素相邻,便于跳过重复。
  2. 同层去重:在同一递归层级中,跳过与前一个元素相同的候选值。
  3. 剪枝优化:提前终止无效路径的探索。

3.2 代码实现

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;class Solution {public List<List<Integer>> combinationSum2(int[] candidates, int target) {List<List<Integer>> result = new ArrayList<>();Arrays.sort(candidates); // 必须排序以处理重复元素backtrack(candidates, target, 0, new ArrayList<>(), result);return result;}private void backtrack(int[] candidates, int remain, int start, List<Integer> path, List<List<Integer>> result) {if (remain == 0) {result.add(new ArrayList<>(path)); // 记录有效组合return;}for (int i = start; i < candidates.length; i++) {// 跳过同一层中的重复元素if (i > start && candidates[i] == candidates[i - 1]) continue; if (candidates[i] > remain) break; // 剪枝:后续元素更大path.add(candidates[i]);backtrack(candidates, remain - candidates[i], i + 1, path, result); // i+1避免重复使用path.remove(path.size() - 1); // 回溯}}
}

3.3 关键点解析

  • 去重逻辑if (i > start && candidates[i] == candidates[i-1])
    • i > start确保只在同层级跳过重复元素(如第一层循环),允许不同层级使用相同值(如[1,1,6])。
  • 剪枝优化:由于数组已排序,当candidates[i] > remain时,后续元素必然无效,直接终止循环。

3.4 示例分析

以输入candidates = [1,1,2,5,6,7,10], target = 8为例:

  1. 第一层选第一个1,进入递归remain=7
  2. 第二层从索引1开始,跳过第二个1i=1 == start=1,不触发跳过),选2后继续递归。
  3. 有效组合包括[1,1,6][1,2,5]等,确保无重复。

4. 总结对比

问题特性组合总和I组合总和II
候选数组元素无重复可能包含重复
元素使用规则可重复使用不可重复使用
核心处理剪枝优化剪枝 + 同层去重
时间复杂度O(N^(T/M))O(2^N)

5. 常见问题

Q1:为什么必须排序?

排序是实现剪枝和去重的前提条件:

  • 剪枝:有序数组可提前终止无效路径。
  • 去重:相同元素相邻,便于跳过重复。

Q2:去重逻辑为何用i > start

  • i > start确保只在同一层级跳过重复元素,例如:当start=0i=1时,若candidates[1] == candidates[0],则跳过第二个1,避免生成[1,1,6][1,1,6]的重复组合。

通过本文,可以掌握使用回溯算法解决组合总和问题的核心技巧,理解剪枝与去重的实现原理,并能够举一反三处理类似问题。

http://www.dtcms.com/wzjs/23004.html

相关文章:

  • 专业的网站优化公司排名无锡百度竞价公司
  • ui设计是什么类灰色关键词排名优化
  • 沈阳做网站哪家好关联词有哪些类型
  • 天津网站建设流程seogw
  • 网站做淘客如何实现网站的快速排名
  • 跨境电商快递怎么发到国外上海网站排名seo公司
  • 常德外贸网站优化推广seo交流
  • 工作中存在的问题和不足优化设计单元测试卷
  • 名字做头诗的网站媒体网站
  • 找人开发软件去什么网站百度搜索下载app
  • 网站建设与维护制作网页上海关键词排名优化价格
  • wordpress淘客采集插件百度排名优化
  • 山东省建设厅网站地址舆情网站
  • 锡盟本地网站建设山东一级造价师
  • dede中英文企业网站企业为何选择网站推广外包?
  • 网站优化优化怎么做百度如何推广网站
  • 株洲网站建设的公司怎么找智慧软文发稿平台
  • 怎么制作自己的网页沈阳关键词优化报价
  • 建设360导航网站的目的是什么意思静态网站模板
  • 农产品网站建设投标书最好的免费信息发布平台
  • 做租人网站犯法吗外链工具软件
  • 做科普网站网站结构
  • 牌具做网站常用的网络推广的方法有哪些
  • 新网站如何做网站优化免费建站的网站哪个好
  • 做一普通网站需要多少钱网站制作的基本流程
  • ppt网站链接怎么做推广赚钱软件
  • 厦门网站做优化外贸建站推广公司
  • linux xampp wordpress澳门seo推广
  • 企业网站的建设目的包含什么太原网站建设方案咨询
  • 怎样创建网站image目录文件谷歌推广效果怎么样