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.

--------------------------------------------------------------------------------------------------------------

题解: 套用DFS模版居然超时了。。。。看来lzDFS还是不过关啊!

lz怒了有木有,难道一定要DFS一个一个找吗?能不能直接找规律呢?

经过推算,lz终于找到一个规律了,0(N)就能搞定啊!!!

从全排列的产生可以看出,变化都是先从低位开始换位的。(此处高位指的是数组中下标减小的方向)

如果想引起A[i]的变化,需要A[i+1]~A[n]完成一次全排列,即需要 (n-i-1)! 次 这个结果即为 fac(n-i-1).

好吧,貌似好抽象! 给一个形象地例子,尝试着解释一下:

1到9的阶乘如下
fac[~] 分别为:                 
-----------------------------------------------------------------------------
输入 n=  k= src=""
如果 k= 直接返回 src, 当输入为k时,实际需要变化的次数为 k-1次。
因此 k=k- k=
-----------------------------------------------------------------------------
判断第1位是否需要更换: k> fac[] : >
.     更换的下标为: / =     因此des[]=src[]=‘’   des=""     取出src[]         src=""     k%=fac[] :        k= 判断第2位是否需要更换: k> fac[] : >.

    更换的下标为: / =     因此des[]=src[]=‘’。 des=""     取出src[]        src=""     k%=fac[] :       k= 判断第3位是否需要更换: k< fac[] : <.     src的首位不需要变化     因此des[]=src[]=‘’。 des=""     取出src[]        src=""     k没有变化        k= 判断第4位是否需要更换: k> fac[] : >.     更换的下标为: / =
    因此des[]=src[]=‘’。 des=""     取出src[]        src=""     k%=fac[]        k= 判断第5位是否需要更换: k> fac[] : >.     更换的下标为: / =     因此des[]=src[]=‘’。 des=""     取出src[]        src=""     k%=fac[]        k= 判断第6位是否需要更换: k> fac[] : >.     更换的下标为: / =     因此des[]=src[]=‘’。 des=""     取出src[]        src=""     k%=fac[]       k= 判断第7位是否需要更换: k> fac[] : >.     更换的下标为: / =     因此des[]=src[]=‘’。 des=""     取出src[]        src=""     k%=fac[]       k= 判断第8位是否需要更换: k>= fac[] : >=.     更换的下标为: / =     因此des[]=src[]=‘’。 des=""     取出src[]        src=""     k%=fac[]       k= 最后仅剩余src仅有1位,直接添加到des最后 des=”“

ok,上代码!

 class Solution {
public:
vector<int> fac;
string getPermutation(int n, int k) {
string src,des; fac.resize(,);
for(int i=;i<=n;i++) fac[i] = fac[i-]*i; if(k>fac[n]) return des;
for(int m=;m<=n;m++) src+=(''+m); //源字符串初始化 k--;
for(int j=n;j>;j--)
{
if(k>=fac[j-])
{
int temp = k/fac[j-];
k%=fac[j-];
des+=src[temp];
src.erase(temp,);
}
else
{
des+=src[];
src.erase(,);
}
}
des+=src[];
return des;
}
};

转载请注明出处: http://www.cnblogs.com/double-win/ 谢谢!

[LeetCode 题解]: Permutation Sequcence的更多相关文章

  1. LeetCode 题解 Permutation Sequence 需要优化!

    题目大意:给出n和k,找到1..n这些数组成的有序全排列中的第k个. 首先,n的全排列可以分成n组,每一组由n-1个数组成. 例如  3的全排列,分成三组: 1 2 3  和 1 3 2 2 1 3 ...

  2. 【LeetCode题解】二叉树的遍历

    我准备开始一个新系列[LeetCode题解],用来记录刷LeetCode题,顺便复习一下数据结构与算法. 1. 二叉树 二叉树(binary tree)是一种极为普遍的数据结构,树的每一个节点最多只有 ...

  3. LeetCode:60. Permutation Sequence,n全排列的第k个子列

    LeetCode:60. Permutation Sequence,n全排列的第k个子列 : 题目: LeetCode:60. Permutation Sequence 描述: The set [1, ...

  4. leetcode题解-122买卖股票的最佳时期

    题目 leetcode题解-122.买卖股票的最佳时机:https://www.yanbinghu.com/2019/03/14/30893.html 题目详情 给定一个数组,它的第 i 个元素是一支 ...

  5. 【LeetCode题解】3_无重复字符的最长子串(Longest-Substring-Without-Repeating-Characters)

    目录 描述 解法一:暴力枚举法(Time Limit Exceeded) 思路 Java 实现 Python 实现 复杂度分析 解法二:滑动窗口(双指针) 思路 Java 实现 Python 实现 复 ...

  6. 【LeetCode题解】225_用队列实现栈(Implement-Stack-using-Queues)

    目录 描述 解法一:双队列,入快出慢 思路 入栈(push) 出栈(pop) 查看栈顶元素(peek) 是否为空(empty) Java 实现 Python 实现 解法二:双队列,入慢出快 思路 入栈 ...

  7. 【LeetCode题解】232_用栈实现队列(Implement-Queue-using-Stacks)

    目录 描述 解法一:在一个栈中维持所有元素的出队顺序 思路 入队(push) 出队(pop) 查看队首(peek) 是否为空(empty) Java 实现 Python 实现 解法二:一个栈入,一个栈 ...

  8. 【LeetCode题解】844_比较含退格的字符串(Backspace-String-Compare)

    目录 描述 解法一:字符串比较 思路 Java 实现 Python 实现 复杂度分析 解法二:双指针(推荐) 思路 Java 实现 Python 实现 复杂度分析 更多 LeetCode 题解笔记可以 ...

  9. 【LeetCode题解】25_k个一组翻转链表(Reverse-Nodes-in-k-Group)

    目录 描述 解法一:迭代 思路 Java 实现 Python 实现 复杂度分析 解法二:递归(不满足空间复杂度) 思路 Java 实现 Python 实现 复杂度分析 更多 LeetCode 题解笔记 ...

随机推荐

  1. linux weather

  2. [Z] 关于Python Tornado的一些资料

    一个简单的样例: http://osedu.net/article/python/2014-03-18/501.html ioloop的官方doc: http://www.tornadoweb.org ...

  3. Dubbo与Zookeeper、SpringMVC整合和使用(负载均衡

    转载:http://blog.csdn.net/congcong68/article/details/41113239 互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架 ...

  4. Linux运维常见故障排查和处理的33个技巧汇总

    作为linux运维,多多少少会碰见这样那样的问题或故障,从中总结经验,查找问题,汇总并分析故障的原因,这是一个Linux运维工程师良好的习惯.每一次技术的突破,都经历着苦闷,伴随着快乐,可我们还是执着 ...

  5. Sqlserver ROW_NUMBER()

    SELECT ROW_NUMBER() OVER (ORDER BY A.orderdate,A.orderid),* from Sales.Orders A

  6. 全文搜索技术—Solr

    1.   学习计划 1. Solr的安装及配置 a)    Solr整合tomcat b)    Solr后台管理功能介绍 c)    配置中文分析器 2. 使用Solr的后台管理索引库 a)     ...

  7. 必看的 jQuery性能优化的38个建议

    一.注意定义jQuery变量的时候添加var关键字 这个不仅仅是jQuery,所有javascript开发过程中,都需要注意,请一定不要定义成如下: $loading = $('#loading'); ...

  8. Stars URAL - 1028

    就是给你一些星星的坐标,然后求出每个星星的左下角有多少颗星星 题目保证按照Y坐标的顺序给出每个星星的坐标,那么我们就可以说,当输入某个星星的坐标时,此时有多少个星星的横坐标小于它,它左下角就有多少星星 ...

  9. Jenkins 更新最新版本

    一般情况下,war的安装路径在/usr/share/jenkins目录下. 不过也有部分人不喜欢安装在这里,可以通过系统管理(System management)--> 系统信息(System ...

  10. ansible playbook模式及语法

    一.什么是playbook及其组成 什么是playbook playbook 翻译过来就是"剧本" playbook的组成 play:定义的是主机的角色 task:定义的是具体执行 ...