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. NIO编程介绍

    代码: package bhz.nio; import java.io.IOException; import java.net.InetSocketAddress; import java.nio. ...

  2. 「小程序JAVA实战」小程序和后台api通信(28)

    转自:https://idig8.com/2018/08/19/xiaochengxujavashizhanxiaochengxuhehoutaiapitongxin28/ 开发最重要的就是实操! 小 ...

  3. Eclipse注释配置

    新的文件/** * @ClassName: ${type_name}  * @Description: ${todo} * @author ${user} * @date ${date} ${time ...

  4. centos安装rvm报错@curl -L get.rvm.io | bash -s stable fails on cent OS

    It is a security feature introduced in the latest version of RVMhttps://github.com/wayneeseguin/rvm/ ...

  5. 给虚拟机添加eth1网络适配器(网卡)

    1.虚拟机 -- > 设置 2.添加 --> 网络适配器 --> 下一步 3.主机 -- > 完成 -- > 确定 4.修改网卡的配置文件 cd /etc/sysconf ...

  6. Tornado 多进程 & 异步

    另外一篇:http://www.cnblogs.com/xiaoshi657/p/6945208.html 基本版: #coding=utf-8 import tornado.web import t ...

  7. Linux 硬盘工具之hdparm

    安装 yum -y install hdparm 显示硬盘的相关设置 测试硬盘的读取速度 检测IDE硬盘的电源管理模式 [root@cnscn ~]# hdparm -C /dev/sda /dev/ ...

  8. win7下IIS的安装和配置图文教程

    1. 首先是安装IIS.打开控制面板,找到”程序与功能”,点进去 2. 点击左侧”打开或关闭Windows功能” 3. 找到”Internet 信息服务”,按照下图打勾即可 等待安装完成 4. 安装完 ...

  9. 前端开发之JavaScript基础篇三

    主要内容: 1.创建对象的几种方式 2.JavaScript内置对象 3.JavaScript错误--Throw.Try 和 Catch 4.JavaScript 表单验证 一.创建对象的几种方式 1 ...

  10. Android开发实战之补间动画和属性动画

    说起动画,其实一点也不陌生,在使用一款app的时候为了优化用户体验,多多少少的,都会加入动画. 安卓中的动画,分为两大类:补间动画和属性动画.本篇博文会详细介绍总结这两大动画,希望本篇博文对你的学习和 ...