码迷,mamicode.com
首页 > 其他好文 > 详细

2014年美团校招之——输出字典序为第k的排列(0<=k<n!)

时间:2014-09-12 12:03:23      阅读:208      评论:0      收藏:0      [点我收藏+]

标签:美团

bubuko.com,布布扣


思路:

比如:n=4,k=6(k从0开始计数),那么就是从找第四个数,那么看规律


(第一队)
 1234
 1243
 1324
 1342
 1423
 1432
 

(第二队)
 2134
 2143
 2314
 2341
 2413
 2431
 
(第三队)
 。。。。


 我们从第一个数字开始确定,由于确定第一个数了,那么后面的排列组合数是(n-1)!也就是6。问题就是如何确定第一个数,这里k=6,我们算出 k/n=1,说明这个数在第二队中。 那么我们应该把2移到最前面,此时排列就变成了2134。此时问题变为在第二队中找出第k%n=0个数,由于第一个数已经定了,那么我们应该在134中找出第0个数。以此类推。


代码如下:

	//求n的阶乘
	public int getFactorial(int n){
		if(n<0)
			return 0;
		else if(n==0)
			return 1;
		else
			return n*getFactorial(n-1);
	}
	
	
	public String findTheKNum(int n , int k){
		int countOfN = getFactorial(n);
		if(k>countOfN-1||k<0)
			return null;
		
		LinkedList<Integer> list = new LinkedList<Integer>();
		for(int i = 1 ; i<=n ; i++){
			list.add(i);
		}
		for(int exchangeIndex = 0 ; exchangeIndex<list.size()-1 ; exchangeIndex++){
			if(k==0)
				break;
			int fact = getFactorial(n-exchangeIndex-1);
			int index = k/fact;
			k = k%fact;
			index = index + exchangeIndex;
			list.add(exchangeIndex, list.get(index));
			list.remove(index+1);
			
		}
		
		StringBuffer strbuf = new StringBuffer();
		
		for(Integer in : list)
			strbuf.append(in);
		
		return strbuf.toString();
	}


 

2014年美团校招之——输出字典序为第k的排列(0<=k<n!)

标签:美团

原文地址:http://blog.csdn.net/cow__sky/article/details/39226565

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!