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

Corn Fields

时间:2018-08-02 11:18:01      阅读:211      评论:0      收藏:0      [点我收藏+]

标签:i++   std   max   stream   优先   两种   运算   状压dp   code   

首先什么都不填是一种,初值f[0][0]设为1

然后有三种不合法的情况:

                                         1.不肥沃

                                         2.行冲突

                                         3.列冲突

前两种可以预处理,最后计算时枚举上一行的状态,判断

运算符的优先级要注意

不断熟悉状压DP

#include<iostream>
#include<cstdio>
using namespace std;
const int M=1e8;
const int maxn=13;
const int maxm=4096;
int a[maxn][maxn];
int F[maxm],f[maxn][maxm];
bool jd[maxm];
int main(){
    int n,m;
    cin>>n>>m;
    for(int i=1;i<=n;i++)
        for(int j=1;j<=m;j++)
            cin>>a[i][j];
    for(int i=1;i<=n;i++)
        for(int j=1;j<=m;j++)
            F[i]=(F[i]<<1)|a[i][j];//肥沃 不肥沃
    int MAX=1<<m;
    for(int i=0;i<MAX;i++)
        jd[i]=((i&(i<<1))==0)&&((i&(i>>1))==0);//行内冲突 
    f[0][0]=1;//啥也不填先加上 
    for(int i=1;i<=n;i++)
        for(int j=0;j<MAX;j++)
            if(jd[j]&&((j&F[i])==j))
                for(int k=0;k<MAX;k++)
                    if((k&j)==0)f[i][j]=(f[i][j]+f[i-1][k])%M;//列不冲突 
    int ans=0;
    for(int i=0;i<MAX;i++){
        ans+=f[n][i];
        ans%=M;
    }
    cout<<ans<<endl;
    return 0;
} 

 

Corn Fields

标签:i++   std   max   stream   优先   两种   运算   状压dp   code   

原文地址:https://www.cnblogs.com/lcan/p/9405615.html

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