Leetcode 60 Solution
This article provides solution to leetcode question 60 (permutation-sequence)
Access this page by simply typing in "lcs 60" in your browser address bar if you have bunnylol configured.
Leetcode Question Link
https://leetcode.com/problems/permutation-sequence
Solution
class Solution {
public:
string getPermutation(int n, int k) {
vector<int> a(n);
vector<int> b(n + 1);
b[0] = 1;
k--;
for (int i = 1; i <= n; i++)
{
a[i - 1] = i;
b[i] = b[i - 1] * i;
}
for (int i = 0; i < n; i++)
{
if (k >= b[n - 1 - i])
{
int shift = k / b[n - 1 - i];
int target = a[i + shift];
for (int j = i + shift; j > i; j--)
a[j] = a[j - 1];
a[i] = target;
k = k % b[n - 1 - i];
}
}
string res;
for (int i = 0; i < n; i++)
res += to_string(a[i]);
return res;
}
};