LeetCode: Permutations II 解题报告
Permutations II
Given a collection of numbers that might contain duplicates, return all possible unique permutations.
For example,
[1,1,2] have the following unique permutations:
[1,1,2], [1,2,1], and [2,1,1].

SOLUTION 1:
还是经典的递归模板。需要处理的情况是:我们先把Num排序,然后只能连续地选,这样就可以避免生成重复的solution.
例子:1 2 3 4 4 4 5 6 7 8
444这个的选法只能:4, 44, 444连续这三种选法
我们用一个visit的数组来记录哪些是选过的。
 public class Solution {
     public List<List<Integer>> permuteUnique(int[] num) {
         List<List<Integer>> ret = new ArrayList<List<Integer>>();
         if (num == null || num.length == 0) {
             return ret;
         }
         // For deal with the duplicate solution, we should sort it.
         Arrays.sort(num);
         boolean[] visit = new boolean[num.length];
         dfs(num, new ArrayList<Integer>(), ret, visit);
         return ret;
     }
     public void dfs(int[] num, ArrayList<Integer> path, List<List<Integer>> ret, boolean[] visit) {
         int len = num.length;
         if (path.size() == len) {
             ret.add(new ArrayList<Integer>(path));
             return;
         }
         for (int i = 0; i < len; i++) {
             // 只能连续地选,这样就可以避免生成重复的solution.
             // 例子:1 2 3 4 4 4 5 6 7 8
             // 444这个的选法只能:4, 44, 444连续这三种选法
             if (visit[i] || (i != 0 && visit[i - 1] && num[i] == num[i - 1])) {
                 continue;
             }
             // 递归以及回溯
             visit[i] = true;
             path.add(num[i]);
             dfs(num, path, ret, visit);
             path.remove(path.size() - 1);
             visit[i] = false;
         }
     }
 }
SOLUTION 2:
用一个pre来记录选过的值,也可以达到同样的目的,只取第一个可以取到的位置,后面再取也是一样的解。用pre记下来,后面就不要再取同样的值了
// SOLUTION 2:
// 使用一个pre来记录。只取第一个可以取的位置
public void dfs(int[] num, ArrayList<Integer> path, List<List<Integer>> ret, boolean[] visit) {
int len = num.length;
if (path.size() == len) {
ret.add(new ArrayList<Integer>(path));
return;
} long pre = Long.MIN_VALUE;
for (int i = 0; i < len; i++) {
int n = num[i];
// 只取第一个可取的位置,因为别的位置取到的也没有区别
if (visit[i] || pre == n) {
continue;
}
pre = n; // 递归以及回溯
visit[i] = true;
path.add(n);
dfs(num, path, ret, visit);
path.remove(path.size() - 1);
visit[i] = false;
}
}
GITHUB:
https://github.com/yuzhangcmu/LeetCode_algorithm/blob/master/permutation/PermuteUnique.java
LeetCode: Permutations II 解题报告的更多相关文章
- 【LeetCode】Permutations II 解题报告
		[题目] Given a collection of numbers that might contain duplicates, return all possible unique permuta ... 
- 【LeetCode】47. Permutations II 解题报告(Python & C++)
		作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 方法一:递归 方法二:回溯法 日期 题目地址:htt ... 
- LeetCode: N-Queens II 解题报告
		N-Queens II (LEVEL 4 难度级别,最高级5) Follow up for N-Queens problem. 
- LeetCode: Combination Sum 解题报告
		Combination Sum Combination Sum Total Accepted: 25850 Total Submissions: 96391 My Submissions Questi ... 
- LeetCode: Unique Paths II  解题报告
		Unique Paths II Total Accepted: 31019 Total Submissions: 110866My Submissions Question Solution Fol ... 
- 【LeetCode】Pascal's Triangle II 解题报告
		[LeetCode]Pascal's Triangle II 解题报告 标签(空格分隔): LeetCode 题目地址:https://leetcode.com/problems/pascals-tr ... 
- 【LeetCode】375. Guess Number Higher or Lower II 解题报告(Python)
		[LeetCode]375. Guess Number Higher or Lower II 解题报告(Python) 作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://f ... 
- 【LeetCode】731. My Calendar II 解题报告(Python)
		[LeetCode]731. My Calendar II 解题报告(Python) 作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 题 ... 
- 【LeetCode】522. Longest Uncommon Subsequence II 解题报告(Python)
		[LeetCode]522. Longest Uncommon Subsequence II 解题报告(Python) 标签(空格分隔): LeetCode 作者: 负雪明烛 id: fuxuemin ... 
随机推荐
- eclipse 如何修改maven插件本地仓库jar包默认存储位置
			eclipse 如何修改maven插件本地仓库jar包默认存储位置 CreateTime--2018年4月18日11:04:47 Author:Marydon 1.更改eclipse的maven本 ... 
- 〖Android〗/system/etc/audio_policy.conf
			原文件注释说明: # audio hardware module section: contains descriptors for all audio hw modules present on t ... 
- ASP.NET MVC:通过FileResult向浏览器发送文件
			在 Controller 中我们可以使用 FileResult 向客户端发送文件. FileResult FileResult 是一个抽象类,继承自 ActionResult.在 System.Web ... 
- phpCAS library
			The phpCAS library provides a simple API for authenticating users against a CAS server. phpCAS is co ... 
- easyui panel自适应问题
			项目中要用到easyui,使用也有几年时间了,刚开始使用还不错,毕竟只是简单的增删改查数据,不过到后面越来越觉得easyui不如extjs了,好多复杂一点的问题,easyui表现就力不从心了,题外话就 ... 
- http1.1 协议响应方面参数
			HTTP1.1 提供了一个必须的Host字段,而且建立好一次连接之后可以重复使用.提高用户的上网体验. 响应信息 HTTP/1.1 200 OK ... 
- oracle中number对应java数据类型
			本文转自:http://blog.csdn.net/ludongshun2016/article/details/71453125 数据库中为number类型的字段,在Java类型中对应的有Integ ... 
- 初学HTML一些基本控件语句
			<html> <head> <title> 这是网页的标题</title> </head> <body> <h2>& ... 
- iOS 网络编程 TCP/UDP HTTP
			一.HTTP协议的主要特点: 1. CS模式 2. 简单快速:只需要传送请求方法和路径.(常用方法有GET,HEAD,POST) 3. 灵活:任意对象都可以,类型由Content-Type加以标记 4 ... 
- 【LeetCode】154. Find Minimum in Rotated Sorted Array II (3 solutions)
			Find Minimum in Rotated Sorted Array II Follow up for "Find Minimum in Rotated Sorted Array&quo ... 
