LeetCode题目-46

首页 编程分享 LEET_CODE 正文

leetCode 转载 编程分享 2018-08-18 17:34:34

简介 LeetCode题目-46


✏Leetcode之PHP版题目解析(46. Permutations)


✏描述

给定一组数字,求出所有的排列情况


✏题目实例


✏题目分析

这道题和之前的两题大体思路都是一样的,整体的思路和前两题是一样的,只要修改对应的条件即可。因为这里每个数字在每一个排列中不能被重复利用,我们需要标识一下当前排列的中的遍历的数是否已经在排列当中了。$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;
               }
               
           }

转载链接:https://leetcode.cn/


Tags:


本篇评论 —— 揽流光,涤眉霜,清露烈酒一口话苍茫。


    声明:参照站内规则,不文明言论将会删除,谢谢合作。


      最新评论




ABOUT ME

Blogger:袅袅牧童 | Arkin

Ido:PHP攻城狮

WeChat:nnmutong

Email:nnmutong@icloud.com

标签云