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

外贸网站建设注意湖人队最新消息

外贸网站建设注意,湖人队最新消息,网站找不到首页,网站后台用什么浏览器文章目录力扣39.组合总数题目描述方法1:深搜回溯力扣39.组合总数 题目描述 给你一个 无重复元素 的整数数组 candidates 和一个目标整数 target ,找出 candidates 中可以使数字和为目标数 target 的 所有 不同组合 ,并以列表形式返回。你可…

文章目录

  • 力扣39.组合总数
    • 题目描述
    • 方法1:深搜回溯

力扣39.组合总数

题目描述

给你一个 无重复元素 的整数数组 candidates 和一个目标整数 target ,找出 candidates 中可以使数字和为目标数 target 的 所有 不同组合 ,并以列表形式返回。你可以按 任意顺序 返回这些组合。

candidates 中的 同一个 数字可以 无限制重复被选取 。如果至少一个数字的被选数量不同,则两种组合是不同的。

对于给定的输入,保证和为 target 的不同组合数少于 150 个。

示例 1:

输入:candidates = [2,3,6,7], target = 7
输出:[[2,2,3],[7]]
解释:
2 和 3 可以形成一组候选,2 + 2 + 3 = 7 。注意 2 可以使用多次。
7 也是一个候选, 7 = 7 。
仅有这两种组合。
示例 2:

输入: candidates = [2,3,5], target = 8
输出: [[2,2,2,2],[2,3,3],[3,5]]
示例 3:

输入: candidates = [2], target = 1
输出: []

提示:

1 <= candidates.length <= 30
2 <= candidates[i] <= 40
candidates 的所有元素 互不相同
1 <= target <= 40

方法1:深搜回溯

  • 每一次,我们尝试往组合中添加一个位于给定数组中的数,获得一个新的中间结果状态result
  • 将添加元素后的组合结果和求和结果作为参数或全局变量进入下一次dfs的初始参数
  • 在新的初始参数上,判断当前组合的总和是否等于目标target:
    • 若等于target则作为其中一个结果添加到结果集,然后返回再继续深搜
    • 若结果大于target直接返回再深搜
    • 若结果小于target,则尝试将从当前位置开始的元素及后续元素循环添加到组合中,进行下一次dfs
/*** Return an array of arrays of size *returnSize.* The sizes of the arrays are returned as *returnColumnSizes array.* Note: Both returned array and *columnSizes array must be malloced, assume caller calls free().*/int result[40],sum;int **results;dfs(int *candidates,int candidatesSize,int target,int index,int *returnSize,int * columnSizes,int size){int i;if(sum==target){results[(*returnSize)]=(int *)calloc(40,sizeof(int*));for(i=0;i<size;i++) results[(*returnSize)][i]=result[i]; columnSizes[(*returnSize)++]=size;}else if(sum<target){for(i=index;i<candidatesSize;i++){sum+=candidates[i];result[size]=candidates[i];dfs(candidates,candidatesSize,target,i,returnSize,columnSizes,size+1);sum-=candidates[i];}}else return;}
int** combinationSum(int* candidates, int candidatesSize, int target, int* returnSize, int** returnColumnSizes){ //初始化工作results=(int **)calloc(200,sizeof(int*));*returnSize=0;sum=0;int * columnSizes=(int *)calloc(200,sizeof(int ));memset(result,0,sizeof(int)*40);//深搜开始dfs(candidates,candidatesSize,target,0,returnSize,columnSizes,0);*returnColumnSizes=columnSizes;return results;
}

在这里插入图片描述

http://www.15wanjia.com/news/56237.html

相关文章:

  • 优秀作文网站推荐刷钻业务推广网站
  • 外国购物网站设计风格seo网络优化公司哪家好
  • 学做网站去哪学设计一个简单的网页
  • 网站如何快速被百度收录促销活动推广方案
  • 做网站挣钱快吗安徽网站关键词优化
  • c mvc网站开发网页优化包括
  • 政府网站建设工作存在的不足首页关键词排名
  • 新郑做网站搜索引擎的营销方法有哪些
  • 免费网站建设软件有哪些今日新闻摘抄
  • 菏泽网站开发网站免费软件
  • 做传奇私服网站有钱赚吗攀枝花网站seo
  • 如何快速找到做网站的客户百度网页版 入口
  • 网站建设模板是什么电商具体是做什么的
  • 西宁网站建设报价cu君博規范百度竞价seo排名
  • 玉林市网站建设网站关键词优化费用
  • 做个手机网站有必要吗百度广告买下的订单在哪里找
  • app定制公司seo公司推荐
  • 成都有实力的网站建设关键词搜索网站
  • 移动电商网站开发需求短视频seo排名
  • 上海宝山做网站公司排名厦门seo怎么做
  • 个人网站注册什么域名关键词排名查询
  • 企业网站建设重要性网站搜索工具
  • 网站建设公司应该怎么做推广seo领导屋
  • 做网站 乐清google chrome官网
  • 个人网站允许做内部论坛吗今日头条(官方版本)
  • 橘色网站模板百度快照优化排名怎么做
  • 备案期间怎么访问网站seo全称是什么
  • 做软件测试的网站友情链接交换标准
  • 动态网站制作素材设计培训班学费一般多少
  • 做软件与做网站建设有什么区别百度优化培训