iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > PHP编程 >PHP怎么使用回溯算法计算组合总和
  • 552
分享到

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

2023-06-20 15:06:57 552人浏览 安东尼
摘要

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

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

--结束END--

本文标题: PHP怎么使用回溯算法计算组合总和

本文链接: https://www.lsjlt.com/news/297950.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • PHP怎么使用回溯算法计算组合总和
    本篇内容介绍了“PHP怎么使用回溯算法计算组合总和”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!给定一个数组candidates和一个目标数...
    99+
    2023-06-20
  • php中怎么利用回溯算法计算组合总和
    php中怎么利用回溯算法计算组合总和,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。给定一个数组 candidates 和一个目标数 target ,找出 candidate...
    99+
    2023-06-20
  • 如何用php回溯算法计算组合总和
    本篇内容主要讲解“如何用php回溯算法计算组合总和”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何用php回溯算法计算组合总和”吧!给定一个数组 candidates 和一个目标数 targe...
    99+
    2023-06-20
  • php回溯算法计算组合总和的方法
    本文小编为大家详细介绍“php回溯算法计算组合总和的方法”,内容详细,步骤清晰,细节处理妥当,希望这篇“php回溯算法计算组合总和的方法”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识...
    99+
    2022-10-19
  • php回溯算法计算组合总和的实例代码
    给定一个数组 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 target 的组合。 candidates 中的每个数字在每个组...
    99+
    2022-11-12
  • 回溯算法之怎么求组合
    本篇内容介绍了“回溯算法之怎么求组合”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!回溯算法大家是不是已经快...
    99+
    2022-10-19
  • C++回溯算法中组合的相关问题怎么解决
    这篇文章主要讲解了“C++回溯算法中组合的相关问题怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++回溯算法中组合的相关问题怎么解决”吧!回溯算法模板void backtracki...
    99+
    2023-07-05
  • PHP怎么用回溯算法求解子集问题
    本篇内容介绍了“PHP怎么用回溯算法求解子集问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!回溯算法实际上一个类似枚举的搜索尝试过程,主要...
    99+
    2023-06-20
  • PHP怎么计算数组元素总和
    这篇文章主要介绍“PHP怎么计算数组元素总和”,在日常操作中,相信很多人在PHP怎么计算数组元素总和问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PHP怎么计算数组元素总和”的疑惑有所帮助!接下来,请跟着小编...
    99+
    2023-06-20
  • 使用PHP的array_sum()函数计算数组中所有元素的总和
    使用PHP的array_sum()函数计算数组中所有元素的总和PHP提供了强大的数组处理函数,其中array_sum()函数可以计算一个数组中所有元素的总和。在本文中,将详细介绍如何使用array_sum()函数,并提供一些相关的代码示例。...
    99+
    2023-11-04
    计算 PHP array_sum()
  • 怎么在Java中使用线程计算数组和
    怎么在Java中使用线程计算数组和?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。代码一:五个线程交替累加计算数组之和,这种方法其实不如单线程直接累加快,因为交替累加需要前一...
    99+
    2023-06-15
  • PHP怎么计算两个给定整数值的总和以及两个值相同时返回其总和的三倍
    这篇文章主要介绍“PHP怎么计算两个给定整数值的总和以及两个值相同时返回其总和的三倍”,在日常操作中,相信很多人在PHP怎么计算两个给定整数值的总和以及两个值相同时返回其总和的三倍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法...
    99+
    2023-06-20
  • 使用php怎么实现一个数组排序算法
    使用php怎么实现一个数组排序算法?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。php是什么语言php,一个嵌套的缩写名称,是英文超级文本预处理语言(PHP:Hypertext...
    99+
    2023-06-14
  • Vue中的watch侦听器、计算属性、Vue-cli和组件怎么使用
    这篇文章主要介绍了Vue中的watch侦听器、计算属性、Vue-cli和组件怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue中的watch侦听器、计算属性、Vue-cli和组件怎么使用文章都会有所收...
    99+
    2023-06-30
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作