[LeetCode 题解]: Permutation Sequcence
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):
"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.
--------------------------------------------------------------------------------------------------------------
题解: 套用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的更多相关文章
- LeetCode 题解 Permutation Sequence 需要优化!
题目大意:给出n和k,找到1..n这些数组成的有序全排列中的第k个. 首先,n的全排列可以分成n组,每一组由n-1个数组成. 例如 3的全排列,分成三组: 1 2 3 和 1 3 2 2 1 3 ...
- 【LeetCode题解】二叉树的遍历
我准备开始一个新系列[LeetCode题解],用来记录刷LeetCode题,顺便复习一下数据结构与算法. 1. 二叉树 二叉树(binary tree)是一种极为普遍的数据结构,树的每一个节点最多只有 ...
- LeetCode:60. Permutation Sequence,n全排列的第k个子列
LeetCode:60. Permutation Sequence,n全排列的第k个子列 : 题目: LeetCode:60. Permutation Sequence 描述: The set [1, ...
- leetcode题解-122买卖股票的最佳时期
题目 leetcode题解-122.买卖股票的最佳时机:https://www.yanbinghu.com/2019/03/14/30893.html 题目详情 给定一个数组,它的第 i 个元素是一支 ...
- 【LeetCode题解】3_无重复字符的最长子串(Longest-Substring-Without-Repeating-Characters)
目录 描述 解法一:暴力枚举法(Time Limit Exceeded) 思路 Java 实现 Python 实现 复杂度分析 解法二:滑动窗口(双指针) 思路 Java 实现 Python 实现 复 ...
- 【LeetCode题解】225_用队列实现栈(Implement-Stack-using-Queues)
目录 描述 解法一:双队列,入快出慢 思路 入栈(push) 出栈(pop) 查看栈顶元素(peek) 是否为空(empty) Java 实现 Python 实现 解法二:双队列,入慢出快 思路 入栈 ...
- 【LeetCode题解】232_用栈实现队列(Implement-Queue-using-Stacks)
目录 描述 解法一:在一个栈中维持所有元素的出队顺序 思路 入队(push) 出队(pop) 查看队首(peek) 是否为空(empty) Java 实现 Python 实现 解法二:一个栈入,一个栈 ...
- 【LeetCode题解】844_比较含退格的字符串(Backspace-String-Compare)
目录 描述 解法一:字符串比较 思路 Java 实现 Python 实现 复杂度分析 解法二:双指针(推荐) 思路 Java 实现 Python 实现 复杂度分析 更多 LeetCode 题解笔记可以 ...
- 【LeetCode题解】25_k个一组翻转链表(Reverse-Nodes-in-k-Group)
目录 描述 解法一:迭代 思路 Java 实现 Python 实现 复杂度分析 解法二:递归(不满足空间复杂度) 思路 Java 实现 Python 实现 复杂度分析 更多 LeetCode 题解笔记 ...
随机推荐
- [Z]图灵奖获得者Richard Karp讲述Berkeley CS的发展史
A Personal View of Computer Science at Berkeley 赤裸裸的吊炸天
- LeetCode题解 #1 Two Sum
在LeetCode做的第一到题 题目大意:给出n个数,在其中找出和为一个特定数的两个数. Input: numbers={2, 7, 11, 15}, target=9Output: index1=1 ...
- mongodb(五)
mongoDB 启动配置祥讲导出,导入,运行时备份Fsync锁,数据修复用户管理,安全认证 1.启动项 mongod --help 1.1利用config配置文件来启动数据库改变端口为8888 mon ...
- tnsping命令解析
tnsping命令格式: tnsping <service_name> n n的意义是可以让tnsping ping多次 例: c:\Documents and Settings\Tony ...
- ubuntu 安装 rtpengine
摘要 RtpEngine推荐使用Debian系统,可以看出Debian系统的安装是最简单的.我是基于ubuntu18.04安装的.需要注意的是如果你的Ubuntu系统版本太低,安装时会遇到各种的版本太 ...
- 大数据Hadoop生态圈:Pig和Hive
前言 Pig最早是雅虎公司的一个基于Hadoop的并行处理架构,后来Yahoo将Pig捐献给Apache的一个项目,由Apache来负责维护,Pig是一个基于 Hadoop的大规模数据分析平台. Pi ...
- java 修改文件
public void fileAlter(String fileName,String content) throws IOException{ BufferedRe ...
- CyclicBarrier的使用
最近一直整并发这块东西,顺便写点Java并发的例子,给大家做个分享,也强化下自己记忆,如果有什么错误或者不当的地方,欢迎大家斧正. CyclicBarrier是一种多线程并发控制实用工具,和Count ...
- VUE,使用物理引擎Box2D设计类愤怒小鸟的击球游戏--基本架构设置
- 108.Convert Sorted Array to Binary Search Tree(Array; Divide-and-Conquer, dfs)
Given an array where elements are sorted in ascending order, convert it to a height balanced BST. 思路 ...