46. Permutations

文章目录

  • 1题目理解
  • 2 回溯
  • 3 47. Permutations II

1题目理解

Given an array nums of distinct integers, return all the possible permutations. You can return the answer in any order.
输入:整数数组nums,所有元素不相同
输出:数组的所有可能的排列

例如:
Input: nums = [1,2,3]
Output: [[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]

2 回溯

所有排列是指nums中的每一个元素,在每个位置都会出现一次。
有一个长度为n的空数组,第0位元素可能是1、2、3任意一个。第1位也一样。但是这里前面的位置选了的元素,在后面位置就不能使用了。所以,我们可以用一个数组记录哪些元素已经被使用过。

class Solution {private List<List<Integer>> answer;private boolean[] visited;private int[] nums;public List<List<Integer>> permute(int[] nums) {answer = new ArrayList<List<Integer>>();this.nums = nums;visited = new boolean[nums.length];dfs(0,new int[nums.length]);return answer;}private void dfs(int index,int[] items){if(index == this.nums.length){List<Integer> list = new ArrayList<Integer>();for(int n : items){list.add(n);}answer.add(list);return;}for(int i =0;i<nums.length;i++){if(!visited[i]){visited[i] = true;items[index] = nums[i];dfs(index+1,items);visited[i]=false;}}}
}

时间复杂度O(n∗n!)O(n*n!)O(nn!)。首先dfs调用次数是n!。在最后结果放入结果集有一个拷贝操作n。所以最终是O(n∗n!)O(n*n!)O(nn!)

3 47. Permutations II

与46类似,但是输入nums可能包含重复元素。
例如:
Input: nums = [1,1,2]
Output:
[[1,1,2],
[1,2,1],
[2,1,1]]
分析:重复元素之前有处理经验了。对数组先排序。
对于第0个位置的元素可能是1、2。选择了第一个1,第二个1就可以跳过了。否则就重复了。
代码只要在之前代码上改一下即可。

class Solution {private List<List<Integer>> answer;private boolean[] visited;private int[] nums;public List<List<Integer>> permuteUnique(int[] nums) {answer = new ArrayList<List<Integer>>();Arrays.sort(nums);this.nums = nums;visited = new boolean[nums.length];dfs(0,new int[nums.length]);return answer;}private void dfs(int index,int[] items){if(index == this.nums.length){List<Integer> list = new ArrayList<Integer>();for(int n : items){list.add(n);}answer.add(list);return;}for(int i = 0;i<nums.length;i++){if(!visited[i]){visited[i] = true;items[index] = nums[i];dfs(index+1,items);visited[i]=false;while(i+1<nums.length && nums[i+1]==nums[i]) i++;}}}
}

时间复杂度最坏情况下上O(n∗n!)O(n*n!)O(nn!)。首先dfs调用次数是n!。在最后结果放入结果集有一个拷贝操作n。所以最终是O(n∗n!)O(n*n!)O(nn!)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/424225.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

第九十九期:可以编写代码的代码:代码生成的利与弊

代码生成的当前状态是无处不在的&#xff08;2019年春季&#xff09;。REST API的数量激增&#xff0c;导致在过去十年中针对各种编程语言和环境开发的API客户端生成器种类繁多。 作者&#xff1a;约翰麦克马洪 代码生成的当前状态 代码生成的当前状态是无处不在的&#xff0…

TD商用将迈重要一步 六大运营商年底建网试验

TD商用将迈重要一步 六大运营商年底建网试验 中国电信、中国网通、中国移动、中国联通、中国铁通和中国卫通同时开动 TD-SCDMA独立组网实验即将迈出重要一步。 昨天记者从知情人士处获悉&#xff0c;如无意外&#xff0c;参加信产部组织的TD-SCDMA外场第三阶段测试的系统厂商将…

天气预报的Ajax效果

最近在网站上看了很多显示实时天气预报的&#xff0c;挺实用而且用户体验也不错。对用户的帮助也比较大&#xff0c;用户可以通过你的网站了解到实时的天气信息。感觉比较有意思&#xff0c;于是自己钻研了一下其中的实现方法。于是决定把代码分享给大家&#xff0c;希望能对大…

784. Letter Case Permutation

文章目录1 题目理解2 回溯1 题目理解 Given a string S, we can transform every letter individually to be lowercase or uppercase to create another string. Return a list of all possible strings we could create. You can return the output in any order. 输入&…

第一百期:Java架构师:高并发下的流量控制

这个时候如果不做任何保护措施&#xff0c;服务器就会承受很大的处理压力&#xff0c;请求量很高&#xff0c;服务器负载也很高&#xff0c;并且当请求超过服务器承载极限的时候&#xff0c;系统就会崩溃&#xff0c;导致所有人都不能访问。 作者&#xff1a;IT技术分享 这个…

DB2常用傻瓜问题1000问(之一)

1.DB2产品的级别有那些?企业版的 ENTERPRISE EDITION工作组版 WORK GROUP EDITION企业扩展版 ENTERPRISE EXTEND EDEDITION个人版的 PERSONAL EDITION卫星版的 SATELLITE EDITION微型版的 EVERYPLACE2.可以连接到DB2数据库的产品有哪些?  DB2客户…

OpenCV学习笔记:矩阵的掩码操作

矩阵的掩码操作很简单。其思想是&#xff1a;根据掩码矩阵&#xff08;也称作核&#xff09;重新计算图像中每个像素的值。掩码矩阵中的值表示近邻像素值&#xff08;包括该像素自身的值&#xff09;对新像素值有多大影响。从数学观点看&#xff0c;我们用自己设置的权值&#…

spring mvc学习(15)Referenced file contains errors

SSM项目中出现Referenced file contains errors (http://www.springframework.org/schema/mvc/spring-mvc-3.0.xs 2019-01-20 22:37:06 薛定谔小猫Historia 阅读数 468更多 分类专栏&#xff1a; java及其框架学习 版权声明&#xff1a;本文为博主原创文章&#xff0c;遵循…

996. Number of Squareful Arrays

文章目录1 题目理解2 回溯分析1 题目理解 Given an array A of non-negative integers, the array is squareful if for every pair of adjacent elements, their sum is a perfect square. Return the number of permutations of A that are squareful. Two permutations A1…

[置顶] export命令-linux

export 命令 功能说明&#xff1a; 设置或显示环境变量。 语 法&#xff1a; export [-fnp][变量名称][变量设置值] 补充说明&#xff1a; 在shell中执行程序时&#xff0c;shell会提供一组环境变量。 export可新增&#xff0c;修改或删除环境变量&#xff0c;供后续执行的程…

商业业智能的概念

商业业智能是什么?简而言之,它是能够帮助用户对自身业务经营做出正确明智决定的工具。一般现代化的业务操作,通常都会产生大量的数据,如订单、库存、交易帐目、通话记录、及客户资料等。如何利用这些数据增进对业务情况的了解,帮助我们在业务管理及发展上作出及时、正确的判断…

spring mvc学习(16)Could not publish server configuration for Tomcat v8.0 Server at localhost.

这个问题本质是我们有多个重名项目&#xff0c;为什么我们会有多个重名项目&#xff0c;其实一般都是我们删除以前的项目&#xff0c;然后再把它重新导进eclipse时以前的项目删除不彻底造成的&#xff0c;以前的项目在"Servers"里面的"server.xml"文件下的…

产品管理:启示录 - 特约客户、产品验证、原型测试

• 如何挑选有潜力的产品&#xff1f; • 如何证明产品设计符合用户需求&#xff1f; • 如何确认产品设计满足三个基本条件&#xff1f; • 如何运用敏捷方法管理产品&#xff1f; • …… 这是《启示录》上说的一些话&#xff0c;去年看了一下&#xff0c;和团队分享了其中几…

37. Sudoku Solver

文章目录1 题目理解2 回溯1 题目理解 Write a program to solve a Sudoku puzzle by filling the empty cells. A sudoku solution must satisfy all of the following rules: Each of the digits 1-9 must occur exactly once in each row. Each of the digits 1-9 must oc…

spring mvc学习(17)Intellij IDEA创建maven项目无java文件问题

1.解决之前项目结构如下&#xff1a; 2.选择File->Project Structure... 3.选择Modules选项卡下面的Sources项&#xff0c;在main文件夹上右键&#xff0c;选择New Folder...并点击OK   4.输入要创建的文件夹名称java&#xff0c;并点击OK继续 5.在创建好的java文件夹上右…

SQL Server 2005中的ROW_NUMBER和RANK

下面介绍两个SQL Server 2005 中的新东东&#xff1a;ROW_NUMBER返回结果集分区内行的序列号&#xff0c;每个分区的第一行从 1 开始。语法&#xff1a;ROW_NUMBER ( ) OVER ( [ <partition_by_clause> ] <order_by_clause> )备注&#xff1a;ORDER BY 子句可确…

day33-1 线程队列

线程队列 线程队列就是一个普通的容器&#xff0c;使用import queue&#xff0c;用法与进程Queue一样 先进先出 from queue import Queueq Queue() q.put(2) q.put(a) q.put((2, 1))print(q.get()) # 2 print(q.get()) # a print(q.get()) # (2, 1) 后进先出&#xff1a;…

51. N-Queens

文章目录1 题目理解2 回溯2.1 直观解法2.2 按行遍历1 题目理解 The n-queens puzzle is the problem of placing n queens on an n x n chessboard such that no two queens attack each other. Given an integer n, return all distinct solutions to the n-queens puzzle. …

第一百零一期:如何处理ASP .NET Core中的cookie?

本文介绍了ASP.NET Core Web应用程序中利用cookie存储和检索针对特定用户的信息。 作者&#xff1a;布加迪编译 【51CTO.com快译】cookie是通常用于存储有关用户信息的一条数据&#xff0c;存储在用户的计算机上。在大多数浏览器中&#xff0c;每个cookie都存储为一个小文件&a…

男生给女生最牛B的告白

1、别以为平胸就说明自己有脑&#xff0c;别以为自己笨就一定丰满。基本上没有男人会笨到认为脑子和胸部有任何联系. 2、爱不爱你&#xff1f;别tm一直问偶这个问题。什么也不说&#xff0c;你丫哭&#xff1b;犹豫了一会说&#xff0c;你丫说不坚决&#xff1b;脱口而出你丫又…