我的编程空间,编程开发者的网络收藏夹
学习永远不晚

PHP怎么使用回溯算法计算组合总和

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

PHP怎么使用回溯算法计算组合总和

本篇内容介绍了“PHP怎么使用回溯算法计算组合总和”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

给定一个数组candidates和一个目标数target,找出candidates中所有可以使数字和为target的组合。这时候我们应该怎么做?今天小编带大家了解一下。

给定一个数组 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 target 的组合。

candidates 中的每个数字在每个组合中只能使用一次。

说明:

所有数字(包括目标数)都是正整数。 解集不能包含重复的组合。

示例 1:

输入: candidates = [10,1,2,7,6,1,5], target = 8,所求解集为:[ [1, 7], [1, 2, 5], [2, 6], [1, 1, 6]]

示例 2:

输入: candidates = [2,5,2,1,2], target = 5,所求解集为:[  [1,2,2],  [5]]

解题思路

直接参考 回溯算法团灭排列/组合/子集问题

代码

class Solution {        public $res = [];    function combinationSum2($candidates, $target) {        sort($candidates);   // 排序        $this->dfs([], $candidates, $target, 0);        return $this->res;    }    function dfs($array, $candidates, $target, $start) {        if ($target < 0) return;        if ($target === 0) {            $this->res[] = $array;            return;        }        $count = count($candidates);        for ($i = $start; $i < $count; $i++) {            if ($i !== $start && $candidates[$i] === $candidates[$i - 1]) continue;            $array[] = $candidates[$i];            $this->dfs($array, $candidates, $target - $candidates[$i], $i + 1);//数字不能重复使用,需要+1            array_pop($array);        }    }}

额外:

给定一个无重复元素的数组 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 target 的组合。

candidates 中的数字可以无限制重复被选取。

区别是允许重复选择,在上一题基础上之改动了两处就搞定了。

class Solution {        public $res = [];    function combinationSum($candidates, $target) {        sort($candidates);   // 排序        $this->dfs([], $candidates, $target, 0);        return $this->res;    }    function dfs($array, $candidates, $target, $start) {        if ($target < 0) return;        if ($target === 0) {            $this->res[] = $array;            return;        }        $count = count($candidates);        for ($i = $start; $i < $count; $i++) {            // if ($i !== $start && $candidates[$i] === $candidates[$i - 1]) continue; // 注释掉去重的代码            $array[] = $candidates[$i];            $this->dfs($array, $candidates, $target - $candidates[$i], $i);//数字能重复使用, 不需要+1            array_pop($array);        }    }}

额外:

找出所有相加之和为 n 的 k 个数的组合。组合中只允许含有 1 - 9 的正整数,并且每种组合中不存在重复的数字。

限制被选中方案中的元素数量

class Solution {    public $res = [];        function combinationSum3($k, $n) {        $this->dfs([], [1,2,3,4,5,6,7,8,9], $n, 0, $k);        return $this->res;    }    function dfs($array, $candidates, $n, $start, $k) {        if ($n < 0) return;        if ($n === 0 && count($array) === $k) {            $this->res[] = $array;            return;        }        for ($i = $start; $i < 9; $i++) {            if ($i !== $start && $candidates[$i] === $candidates[$i - 1]) continue;            $array[] = $candidates[$i];            $this->dfs($array, $candidates, $n - $candidates[$i], $i + 1, $k);            array_pop($array);        }    }}

“PHP怎么使用回溯算法计算组合总和”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

PHP怎么使用回溯算法计算组合总和

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

PHP怎么使用回溯算法计算组合总和

本篇内容介绍了“PHP怎么使用回溯算法计算组合总和”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!给定一个数组candidates和一个目标数
2023-06-20

php中怎么利用回溯算法计算组合总和

php中怎么利用回溯算法计算组合总和,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。给定一个数组 candidates 和一个目标数 target ,找出 candidate
2023-06-20

如何用php回溯算法计算组合总和

本篇内容主要讲解“如何用php回溯算法计算组合总和”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何用php回溯算法计算组合总和”吧!给定一个数组 candidates 和一个目标数 targe
2023-06-20

C++回溯算法中组合的相关问题怎么解决

这篇文章主要讲解了“C++回溯算法中组合的相关问题怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++回溯算法中组合的相关问题怎么解决”吧!回溯算法模板void backtracki
2023-07-05

PHP怎么用回溯算法求解子集问题

本篇内容介绍了“PHP怎么用回溯算法求解子集问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!回溯算法实际上一个类似枚举的搜索尝试过程,主要
2023-06-20

PHP怎么计算数组元素总和

这篇文章主要介绍“PHP怎么计算数组元素总和”,在日常操作中,相信很多人在PHP怎么计算数组元素总和问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PHP怎么计算数组元素总和”的疑惑有所帮助!接下来,请跟着小编
2023-06-20

使用PHP集合类高效计算数组交集和并集

使用 php 集合类可高效计算数组交集和并集,具体步骤如下:利用 intersect() 方法计算交集:同时出现在两个数组中的元素。利用 union() 方法计算并集:出现在任意一个数组中的元素。实战案例:通过比较购物车内容,了解用户重叠商
使用PHP集合类高效计算数组交集和并集
2024-05-01

使用PHP的array_sum()函数计算数组中所有元素的总和

使用PHP的array_sum()函数计算数组中所有元素的总和PHP提供了强大的数组处理函数,其中array_sum()函数可以计算一个数组中所有元素的总和。在本文中,将详细介绍如何使用array_sum()函数,并提供一些相关的代码示例。
使用PHP的array_sum()函数计算数组中所有元素的总和
2023-11-04

怎么在Java中使用线程计算数组和

怎么在Java中使用线程计算数组和?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。代码一:五个线程交替累加计算数组之和,这种方法其实不如单线程直接累加快,因为交替累加需要前一
2023-06-15

使用php怎么实现一个数组排序算法

使用php怎么实现一个数组排序算法?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。php是什么语言php,一个嵌套的缩写名称,是英文超级文本预处理语言(PHP:Hypertext
2023-06-14

PHP中使用lambda函数计算数组交集和并集的优雅方法

在 php 中,lambda 函数可用作处理数组交集和并集的优雅方法。对于交集,使用 array_filter() 函数结合 lambda 函数来过滤元素,确定它们是否存在于另一个数组中;对于并集,使用 array_reduce() 函数结
PHP中使用lambda函数计算数组交集和并集的优雅方法
2024-05-04

PHP怎么计算两个给定整数值的总和以及两个值相同时返回其总和的三倍

这篇文章主要介绍“PHP怎么计算两个给定整数值的总和以及两个值相同时返回其总和的三倍”,在日常操作中,相信很多人在PHP怎么计算两个给定整数值的总和以及两个值相同时返回其总和的三倍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法
2023-06-20

Vue中的watch侦听器、计算属性、Vue-cli和组件怎么使用

这篇文章主要介绍了Vue中的watch侦听器、计算属性、Vue-cli和组件怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue中的watch侦听器、计算属性、Vue-cli和组件怎么使用文章都会有所收
2023-06-30

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录