[LeetCode] 46. 全排列(回溯)
###题目
给定一个没有重复数字的序列,返回其所有可能的全排列。
示例:
输入: [1,2,3]
输出:
[
[1,2,3],
[1,3,2],
[2,1,3],
[2,3,1],
[3,1,2],
[3,2,1]
]
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/permutations
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
###题解
- 回溯
- 使用位掩码数组的方式可以模拟集合拿出放入,以处理int[] num的拿出放入,否则用集合在遍历的同时要拿出放入不易实现。
- 最后加到结果集合的结果要使用拷贝,若是将结果以引用方式存入结果集若后面更改则会造成结果集的结果错误。
###代码
class Solution {
	public List<List<Integer>> permute(int[] nums) {
		List<List<Integer>> ansList = new LinkedList<>();
		boolean[] visited = new boolean[nums.length];
		traceBack(nums, visited, new LinkedList<>(), ansList);
		return ansList;
	}
	private void traceBack(int[] nums, boolean[] visited, LinkedList<Integer> ans,
			List<List<Integer>> ansList) {
		if (ans.size() == nums.length) {
			ansList.add(new LinkedList<>(ans));// 要new 否则存在ansList里的ans最后都被清成空List了
			return;
		}
		for (int i = 0; i < visited.length; ++i) {
			if (!visited[i]) {
				ans.addLast(nums[i]);
				visited[i] = true;
				traceBack(nums, visited, ans, ansList);
				ans.removeLast();
				visited[i] = false;
			}
		}
	}
}
[LeetCode] 46. 全排列(回溯)的更多相关文章
- 每日一题-——LeetCode(46)全排列
		题目描述: 给定一个没有重复数字的序列,返回其所有可能的全排列.输入: [1,2,3]输出:[ [1,2,3], [1,3,2], [2,1,3], [2,3,1], [3,1,2], [3,2,1] ... 
- Java实现 LeetCode 46 全排列
		46. 全排列 给定一个没有重复数字的序列,返回其所有可能的全排列. 示例: 输入: [1,2,3] 输出: [ [1,2,3], [1,3,2], [2,1,3], [2,3,1], [3,1,2] ... 
- [leetcode] 46. 全排列(Java)
		46. 全排列 这题我们可以借用31. 下一个排列写的nextPermutation函数来做,稍微改造一下即可 注意要先给nums排个序 class Solution { // 当没有下一个排列时re ... 
- leetcode 46. 全排列 及 47. 全排列 II
		46. 全排列 问题描述 给定一个没有重复数字的序列,返回其所有可能的全排列. 示例: 输入: [1,2,3] 输出: [ [1,2,3], [1,3,2], [2,1,3], [2,3,1], [3 ... 
- LeetCode 46 全排列
		题目: 给定一个没有重复数字的序列,返回其所有可能的全排列. 示例: 输入: [1,2,3] 输出: [ [1,2,3], [1,3,2], [2,1,3], [2,3,1], [3,1,2], [3 ... 
- LeetCode 46. 全排列(Permutations)
		题目描述 给定一个没有重复数字的序列,返回其所有可能的全排列. 示例: 输入: [1,2,3] 输出: [ [1,2,3], [1,3,2], [2,1,3], [2,3,1], [3,1,2], [ ... 
- 力扣Leetcode 46. 全排列
		全排列 给定一个 没有重复 数字的序列,返回其所有可能的全排列. 示例: 输入: [1,2,3] 输出: [ [1,2,3], [1,3,2], [2,1,3], [2,3,1], [3,1,2], ... 
- LeetCode 46——全排列
		1. 题目 2. 解答 给定一个序列,序列中的任意一个数字都可以作为全排列的最后一位.然后,其余位置元素的确定便是剩余元素的一个全排列,也就是一个子问题. 例子中 [1, 2, 3] 的全排列,最后一 ... 
- leetcode 46 全排列 (python)
		给定一个没有重复数字的序列,返回其所有可能的全排列. 示例: 输入: [1,2,3]输出:[ [1,2,3], [1,3,2], [2,1,3], [2,3,1], [3,1,2], [3,2,1]] ... 
随机推荐
- 洛谷P1036.选数(DFS)
			题目描述 已知 n个整数 x1,x2,-,xn,以及11个整数k(k<n).从n个整数中任选k个整数相加,可分别得到一系列的和.例如当n=4,k=3,4个整数分别为3,7,12,19时,可得全部 ... 
- Selenium数据驱动测试模型和实例
			模块驱动的模型虽然解决了脚本的重复问题,但是需要测试不同数据的用例时,模块驱动的方式就不很适合了. 数据驱动就是数据的改变从而驱动自动化测试的执行,最终引起测试结果的改变. 装载数据的方式可以是列表. ... 
- python基本数据类型(三)
			字典{} 冒号前面是key(键)冒号后面是values(值) 键:值 ==键值对 1.索引 s={ 'name':'lifei', 'age':'', 'sex':'man' } print(s[' ... 
- Python 用DataFrame读  存 excel
			读 代码: import pandas as pd e = r'D:\pywork\12\excel信息表.xlsx' df = pd.DataFrame(pd.read_excel(e)) 存 D. ... 
- javaString详解
			String基础 Java String 类 字符串广泛应用 在 Java 编程中,在 Java 中字符串属于对象,Java 提供了 String 类来创建和操作字符串. 创建字符串 创建字符串最简单 ... 
- Python的pyttsx3安装失败的解决方案
			尝试更新安装工具,然后重试安装: pip install -U setuptools pip install pyttsx3 如果仍不能解决您的问题,您也可以尝试指定pyttsx3的版本 pip in ... 
- Mysql锁【转】
			一.概述 数据库锁定机制简单来说,就是数据库为了保证数据的一致性,而使各种共享资源在被并发访问变得有序所设计的一种规则.对于任何一种数据库来说都需要有相应的锁定机制,所以MySQL自然也不能例外. M ... 
- 【独家】React Native 版本升级指南
			前言 React Native 作为一款跨端框架,有一个最让人头疼的问题,那就是版本更新.尤其是遇到大版本更新,JavaScript.iOS 和 Android 三端的配置构建文件都有非常大的变动,有 ... 
- WPF Devexpress 控件库中ChartControl 实现股票分时走势图
			概要 从事金融行业开发 ,会接触些图表控件,这里我分享一下自己基于DevExpress.Charts.v16.2开发的股票分时走势图的经验. 附上源码:点击跳转 如果需要讨论,Q群:580749909 ... 
- 【Flutter 实战】17篇动画系列文章带你走进自定义动画
			老孟导读:Flutter 动画系列文章分为三部分:基础原理和核心概念.系统动画组件.8篇自定义动画案例,共17篇. 动画核心概念 在开发App的过程中,自定义动画必不可少,Flutter 中想要自定义 ... 
