zoukankan      html  css  js  c++  java
  • 60. Permutation Sequence

    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 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.
    • Given k will be between 1 and n! inclusive.

    Example 1:

    Input: n = 3, k = 3
    Output: "213"
    

    Example 2:

    Input: n = 4, k = 9
    Output: "2314"
    
     
    AC code:
    class Solution {
    public:
        string getPermutation(int n, int k) {
            string s(n, 0);
            iota(s.begin(), s.end(), '1');
            vector<int> fact(n, 1);
            string ans(n, 0);
            for (int i = n-3; i >= 0; --i)
                fact[i] = (n - 1 - i) * fact[i+1];
            k = k - 1;
            for (int i = 0; i < n; ++i) {
                int index = k / fact[i];
                k = k % fact[i];
                ans[i] = s[index];
                s.erase(next(s.begin(), index));
            }
            return ans;
        }
    };
    

    Runtime: 0 ms, faster than 100.00% of C++ online submissions for Permutation Sequence.

    std::iota

    template <class ForwardIterator, class T>
      void iota (ForwardIterator first, ForwardIterator last, T val);
    Store increasing sequence

    Assigns to every element in the range [first,last) successive values of val, as if incremented with ++val after each element is written.

    The behavior of this function template is equivalent to:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    template <class ForwardIterator, class T>
      void iota (ForwardIterator first, ForwardIterator last, T val)
    {
      while (first!=last) {
        *first = val;
        ++first;
        ++val;
      }
    }
     



    Parameters

    first, last
    Forward iterators to the initial and final positions of the sequence to be written. The range used is [first,last), which contains all the elements between first and last, including the element pointed by first but not the element pointed by last.
    val
    Initial value for the accumulator.
    永远渴望,大智若愚(stay hungry, stay foolish)
  • 相关阅读:
    Android酷炫实用的开源框架(UI框架)
    The official raywenderlich.com Objective-C style guide.
    mac os 利用ssh 搭建git server服务器详细教程,以及git基本用法
    创建者模式
    工厂模式之我见
    设计模式的学习
    MSSQL基础
    Ini文件帮助类
    Nuget的使用
    Oracle批量执行脚本文件
  • 原文地址:https://www.cnblogs.com/h-hkai/p/9820845.html
Copyright © 2011-2022 走看看