leetCode_Permutation Sequence

题意:在集合[1,2,...,n]中找出第k个组合序列

思路:相当于把每个组合序列编号,从最高位开始,看看每一位能填几。

代码如下:

string getPermutation(int n, int k)
{
    vector<int> f;
    bool isUsed[10];
    int i,j,t,m;
    string ans;
    f.push_back(1);
    j=1;
    for(i=1; i<=8; i++)
    {
        j=j*i;
        f.push_back(j);
    }
    for(i=1; i<=n; i++) isUsed[i]=false;
    for(i=1; i<=n; i++)
    {

        for(j=n-1; i>=0; j--)
        {
            if(k>j*f[(n-i)])//要注意是j*f[(n-i)]不是f[j]*(n-i)
            {
                k-=j*f[(n-i)];
                j++;
                break;
            }
        }
        m=0;
        for(t=1; t<=n; t++)
        {
            if(isUsed[t]==false) m++;
            if(m==j)
            {
                isUsed[t]=true;
                break;
            }
        }
        switch(t)
        {
        case 1:
            ans+="1";
            break;
        case 2:
            ans+="2";
            break;
        case 3:
            ans+="3";
            break;
        case 4:
            ans+="4";
            break;
        case 5:
            ans+="5";
            break;
        case 6:
            ans+="6";
            break;
        case 7:
            ans+="7";
            break;
        case 8:
            ans+="8";
            break;
        case 9:
            ans+="9";
            break;
        default:
            break;
        }

    }
    return ans;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值