46.全排列

1.题目

在这里插入图片描述

2.解法

class Solution {    
	public List<List<Integer>> permute(int[] nums) {        
		List<List<Integer>> aList = new LinkedList();        
		ArrayList<Integer> true_nums = new ArrayList<Integer>();        
		for (int i : nums) {            
			true_nums.add(i);        
		}       
		int len = nums.length;        
		backtrack(0, len, true_nums, aList);       
		return aList;    
		}
		
    public void backtrack(int first, int len, ArrayList<Integer> nums, 
    List<List<Integer>> aList) {       
    	 if (first == len) {           
    	  aList.add(new ArrayList<Integer>(nums));} 
        for (int i = first; i < len; i++) {           
        	 Collections.swap(nums, first, i);           
          	backtrack(first+1, len, nums, aList);           
          	 Collections.swap(nums, first, i);        
          	 }            
       }
 }

==时间复杂度在这里插入图片描述空间复杂度O(n!)

3.思考

这里是使用的回溯方法
1、当first==n时回溯结束 (终止条件)
2、nums数组中没有swap函数,所以为了方便运算,将nums放到ArrayList中
3、我不太理解List<List> aList = new LinkedList()可以作为引用,全局使用,
nums作为ArrayList,可以在每次回溯时随意改变,难道不会影响原值嘛。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值