程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> C++入門知識 >> [leetCode]Permutation Sequence

[leetCode]Permutation Sequence

編輯:C++入門知識

[leetCode]Permutation Sequence


The set [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):

  1. "123"
  2. "132"
  3. "213"
  4. "231"
  5. "312"
  6. "321"

    Given n and k, return the kth permutation sequence.

    Note: Given n will be between 1 and 9 inclusive.


    public class Solution {
    	int f[];
        public String getPermutation(int n, int k) {
        	f = new int[n+1];
        	if(k>factorial(n)) return "-1";
        	List list = new ArrayList();
            for(int i=1;i<=n;i++){
            	list.add(i);
            }
            StringBuilder sb = new StringBuilder();
            k--;
            while(list.size()>0){
            	int mul = factorial(n-1);
            	int index = k/mul;
            	sb.append(list.get(index));
            	list.remove(index);
            	k = k%mul;
            	n--;
            }
            return sb.toString();
        }
        private int factorial(int num){
        	if(num == 0) return f[0]=1;
        	if(f[num]>0){
        		return f[num];
        	}else{
        		return f[num]=factorial(num-1)*num;
        	}
        	
        }
    }




  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved