2 0 1 9 -6-10 星 期一 开 始 吧
上半年的假终于全剧终了,人一懒惰起来,再调整状态就困难多了
上 一 题 链 接 Leetcode基础刷题之 PHP 解析(40. Combination Sum II)
题 目 描 述
给定一组数字,求出所有的排列情况
题 目 分 析
这道题和之前的两题大体思路都是一样的,整体的思路和前两题是一样的,只要修改对应的条件即可。因为这里每个数字在每一个排列中不能被重复利用,我们需要标识一下当前排列的中的遍历的数是否已经在排列当中了。 $index 用来标识访问的数组下标,一但当前的下标等于数组的总数,说明此时这轮排列结束,把当前排列的值push到最终返回的二维数组中。
/**
* @param Integer[] $nums
* @return Integer[][]
*/
function permute($nums) {
$out=[];
$res=[];
$visited=[];
$this->helper($nums,0,$visited,$out,$res);
return $res;
}
function helper($nums,$index,&$visited,&$out,&$res)
{
if($index==count($nums)){
array_push($res,$out);
return;
}
for($j=0;$j<count($nums);$j++){
if($visited[$j]==1) continue;
$visited[$j]=1;
array_push($out,$nums[$j]);
$this->helper($nums,$index+1,$visited,$out,$res);
array_pop($out);
$visited[$j]=0;
}
}
Github整理地址 : https://github.com/wuqinqiang/leetcode-php
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- Apache Flink 零基础入门(一):基础概念解析
- Apache Flink 零基础入门(一):基础概念解析
- JStorm 源码解析:基础线程模型
- React Hooks 解析(上):基础
- TypeScript基础入门之模块解析(一)
- TypeScript基础入门之模块解析(二)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
HTML 压缩/解压工具
在线压缩/解压 HTML 代码
HTML 编码/解码
HTML 编码/解码