博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Leetcode46——Permutations
阅读量:3977 次
发布时间:2019-05-24

本文共 822 字,大约阅读时间需要 2 分钟。

文章作者:Tyan

博客:  |   | 

1. 问题描述

Given a collection of distinct numbers, return all possible permutations.

For example, [1,2,3] have the following permutations:

[  [1,2,3],  [1,3,2],  [2,1,3],  [2,3,1],  [3,1,2],  [3,2,1]]

2. 求解

递归法

这道题是求数组的全排列,首先可以用递归法,第一次往链表添加一个元素,有n中可能,然后将剩下的元素再添加一个元素到链表中,有n-1种可能,以此类推,直至链表中的元素大小等于数组大小。

public class Solution {
public static List
> result = new ArrayList
>(); public List
> permute(int[] nums) { result.clear(); permutation(nums, new ArrayList()); return result; } public void permutation(int[] nums, List
list) { if(list.size() == nums.length) { result.add(list); return; } for(int i = 0; i < nums.length; i++) { if(!list.contains(nums[i])) { List
subList = new ArrayList
(list); subList.add(nums[i]); permutation(nums, subList); } } }}

转载地址:http://kcwui.baihongyu.com/

你可能感兴趣的文章
Spring Batch 核心概念
查看>>
Spring Batch 例子: 导入定长文件到数据库
查看>>
正则表达式
查看>>
Java I/O
查看>>
序列化
查看>>
Perl 精萃
查看>>
数据类型之列表与数组
查看>>
XStream 环境设置
查看>>
Git 分支
查看>>
Git 冲突
查看>>
Git Merging vs. Rebasing
查看>>
libreoffice/openoffice c/c++转换office格式为pdf
查看>>
Tomcat 7.0 64位免安装解压版 安装及配置
查看>>
Android 网络编程 初级入门(一)
查看>>
No enclosing instance of type Demo06 is accessible.
查看>>
计算机发展中的两大“杀手”
查看>>
MDK5(Keil for ARM) 工程建立时遇到的问题集锦
查看>>
Ubuntu下安装GTK+及Glade开发C应用界面
查看>>
assertion 'GTK_IS_WIDGET (widget)' failed的解决办法
查看>>
Ubuntu登录管理员账户时,输入密码后一直在登录界面循环
查看>>