POJ 3254 Corn Fields 키다리 모양 압DP
XXX 논문을 남겨 두다.
#include <iostream>
#include <algorithm>
#include <cstdlib>
#include <cstdio>
#include <cstring>
#include <queue>
#include <cmath>
#include <stack>
#pragma comment(linker, "/STACK:1024000000");
#define LL long long int
#define ULL unsigned long long int
#define _LL __int64
#define _INF 0x3f3f3f3f
#define INF 4000000
#define Mod 100000000
using namespace std;
int mark[14][14];
ULL dp[13][(1<<12)];
int sta;
bool Match(int s1,int s2,int m)
{
int i,f;
for(i = 1,f = 1;i <= m; ++i)
{
if((s1&f) && (s2&f))
return false;
f <<= 1;
}
return true;
}
bool Is_Valid(int n,int m,int sta)
{
int f,i;
for(i = 1,f = 1;i <= m; ++i)
{
if(sta&f)
{
if(mark[n][i] == 0)
return false;
if(i > 1)
{
if(sta&(f>>1))
return false;
}
}
f <<= 1;
}
return true;
}
int main()
{
int n,m;
ULL ans = 0;
scanf("%d %d",&n,&m);
int i,j,k;
for(i = 1;i <= n; ++i)
{
for(j = 1;j <= m; ++j)
{
scanf("%d",&mark[i][j]);
}
}
int Max = (1<<m)-1;
for(j = 0;j <= Max; ++j)
{
if(Is_Valid(n,m,j) == false)
dp[n][j] = 0;
else
dp[n][j] = 1;
}
for(i = n-1;i >= 1; --i)
{
for(j = 0;j <= Max; ++j)
{
dp[i][j] = 0;
if(Is_Valid(i,m,j))
{
for(k = 0;k <= Max; ++k)
{
if(dp[i+1][k] != 0 && Match(j,k,m))
{
dp[i][j] += dp[i+1][k];
dp[i][j] %= Mod;
}
}
}
}
}
for(ans = 0,i = 0;i <= Max; ++i)
{
ans += dp[1][i];
ans %= Mod;
}
printf("%llu
",ans);
return 0;
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.