LeetCode——Permutation Sequence
2014-11-19 17:06
330 查看
The set
permutations.
By listing and labeling all of the permutations in order,
We get the following sequence (ie, for n = 3):
Given n and k, return the kth permutation sequence.
Note: Given n will be between 1 and 9 inclusive.
原题链接:https://oj.leetcode.com/problems/permutation-sequence/
从n个数的全排列中找出第k个排列。
n开头的排列有(n-1)!个。k/(n-1)!可确定第一个数字,在余下的(n-1)!中找k%(n-1)!个。
public class PermutationSequence {
public String getPermutation(int n, int k) {
List<Integer> list = new ArrayList<Integer>();
for(int i=1;i<=n;i++)
list.add(i);
int mod = 1;
for (int i = 1; i <= n; i++) {
mod = mod * i;
}
k--;
StringBuilder builder = new StringBuilder();
for(int i=0;i<n;i++){
mod /= (n-i);
int index = k / mod;
k %= mod;
builder.append(list.get(index));
list.remove(index);
}
return builder.toString();
}
}
[1,2,3,…,n]contains a total of n! unique
permutations.
By listing and labeling all of the permutations in order,
We get the following sequence (ie, for n = 3):
"123"
"132"
"213"
"231"
"312"
"321"
Given n and k, return the kth permutation sequence.
Note: Given n will be between 1 and 9 inclusive.
原题链接:https://oj.leetcode.com/problems/permutation-sequence/
从n个数的全排列中找出第k个排列。
n开头的排列有(n-1)!个。k/(n-1)!可确定第一个数字,在余下的(n-1)!中找k%(n-1)!个。
public class PermutationSequence {
public String getPermutation(int n, int k) {
List<Integer> list = new ArrayList<Integer>();
for(int i=1;i<=n;i++)
list.add(i);
int mod = 1;
for (int i = 1; i <= n; i++) {
mod = mod * i;
}
k--;
StringBuilder builder = new StringBuilder();
for(int i=0;i<n;i++){
mod /= (n-i);
int index = k / mod;
k %= mod;
builder.append(list.get(index));
list.remove(index);
}
return builder.toString();
}
}
相关文章推荐
- leetcode做题总结,题目Permutation Sequence 2012/03/27
- [LeetCode] Permutation Sequence, Solution
- leetcode:Permutation Sequence (顺序排列第k个序列) 【面试算法题】
- LeetCode-60-Permutation Sequence 暴力递归
- leetcode:回溯——permutation-sequence,
- LeetCode-Permutation SequencePermutation Sequence
- leetcode总结:permutations, permutations II, next permutation, permutation sequence
- LeetCode Permutation Sequence
- LeetCode 60 Permutation Sequence
- LeetCode Permutation Sequence(求排列中的第k个排列是什么)
- leetcode Permutation Sequence
- LeetCode 93 Permutation Sequence
- LeetCode刷题笔录Permutation Sequence
- LeetCode Permutation Sequence
- [Leetcode]#60 Permutation Sequence
- [Leetcode] Permutation Sequence
- leetcode 日经贴,Cpp code -Permutation Sequence
- LeetCode 60 - Permutation Sequence
- LeetCode || Permutation Sequence
- leetcode: Permutation Sequence