2 0 1 9 -6-13 星 期四 开 始 吧
上 一 题 链 接 Leetcode基础刷题之 PHP 解析(47. Permutations II)
题 目 描 述
给定一个不重复的数组,返回它所有的子集,并且不能重复,这两周选择递归的标签其实刷的都是关于回溯法思想,只是实现方式用的是递归。
题 目 分 析
这些题目解释起来的原理都是回溯的解题思路,今天换个方式,画了个运行流程。一层一层的往下找,直到结束,退回一层,继续找,最终的顺序就是图上花的[][1][1,2][1,2,3][2,3]......好吧这图我都看不下去了,将就点,看代码。
/** * @param Integer[] $nums * @return Integer[][] */ function subsets($nums) { $out=[]; $res=[]; $this->helper($nums,0,$out,$res); return $res; } function helper($nums,$index,&$out,&$res){ array_push($res,$out); for($i=$index;$i<count($nums);$i++){ array_push($out,$nums[$i]); $this->helper($nums,$i+1,$out,$res); array_pop($out); } }
Github整理地址 : https://github.com/wuqinqiang/leetcode-php
以上所述就是小编给大家介绍的《Leetcode基础刷题之PHP解析(78. Subsets)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- Apache Flink 零基础入门(一):基础概念解析
- Apache Flink 零基础入门(一):基础概念解析
- JStorm 源码解析:基础线程模型
- React Hooks 解析(上):基础
- TypeScript基础入门之模块解析(一)
- TypeScript基础入门之模块解析(二)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。