码迷,mamicode.com
首页 > 其他好文 > 详细

[POJ 1037] A decorative fence

时间:2018-07-21 21:34:36      阅读:156      评论:0      收藏:0      [点我收藏+]

标签:sizeof   bitset   sed   lex   lis   algo   continue   algorithm   tde   

[题目链接]

          http://poj.org/problem?id=1037

[算法]

         DP

[代码]

        

#include <algorithm>  
#include <bitset>  
#include <cctype>  
#include <cerrno>  
#include <clocale>  
#include <cmath>  
#include <complex>  
#include <cstdio>  
#include <cstdlib>  
#include <cstring>  
#include <ctime>  
#include <deque>  
#include <exception>  
#include <fstream>  
#include <functional>  
#include <limits>  
#include <list>  
#include <map>  
#include <iomanip>  
#include <ios>  
#include <iosfwd>  
#include <iostream>  
#include <istream>  
#include <ostream>  
#include <queue>  
#include <set>  
#include <sstream>  
#include <stdexcept>  
#include <streambuf>  
#include <string>  
#include <utility>  
#include <vector>  
#include <cwchar>  
#include <cwctype>  
#include <stack>  
#include <limits.h> 
using namespace std;
#define MAXN 25

int i,T,n;
long long c;
long long f[MAXN][MAXN][2];
bool used[MAXN];

inline void dp()
{
        int i,j,k;
        f[1][1][0] = f[1][1][1] = 1;
        for (i = 2; i <= 20; i++)
        {
                for (j = 1; j <= i; j++)
                {
                        for (k = j; k < i; k++) f[i][j][0] += f[i - 1][k][1];
                        for (k = 1; k < j; k++) f[i][j][1] += f[i - 1][k][0]; 
                }
        }
}
inline void calc(int n,long long c)
{
        int i,j,rk,k,pre,opt;
        memset(used,false,sizeof(used));
        for (i = 1; i <= n; i++)
        {
                if (f[n][i][1] >= c) 
                {
                        pre = i;
                        opt = 1;
                        break;
                } else c -= f[n][i][1];
                if (f[n][i][0] >= c)
                {
                        pre = i;
                        opt = 0;
                        break;
                } else c -= f[n][i][0];
        }
        printf("%d ",pre);
        used[pre] = true;
        for (i = 2; i <= n; i++)
        {
                opt ^= 1;
                rk = 0;
                for (j = 1; j <= n; j++)
                {
                        if (used[j]) continue;
                        rk++;
                        if ((opt == 0 && j < pre) || (opt == 1 && j > pre))
                        {
                                if (f[n - i + 1][rk][opt] >= c)
                                {
                                        pre = j;
                                        break;
                                } else c -= f[n - i + 1][rk][opt];
                        }
                }
                printf("%d ",pre);
                used[pre] = true;
        }
        printf("\n");
}

int main() 
{
        
        dp();
        scanf("%d",&T);
        while (T--)
        {
                scanf("%d%lld",&n,&c);    
                calc(n,c);
        }
        
        return 0;
    
}

 

[POJ 1037] A decorative fence

标签:sizeof   bitset   sed   lex   lis   algo   continue   algorithm   tde   

原文地址:https://www.cnblogs.com/evenbao/p/9347951.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!