acwing 327. 玉米田
生活随笔
收集整理的這篇文章主要介紹了
acwing 327. 玉米田
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
327. 玉米田
題意:
m * n的土地,有的土地不育,有的可以種植,要求相鄰的土地不能同時種植玉米,問有多少種種植方式
題解:
狀壓dp,先存每一行可能的狀態(tài),然后狀態(tài)轉(zhuǎn)移,注意相鄰不能同時種植除了左右還有上下
代碼:
#include <bits/stdc++.h> using namespace std; const int P=1e9; int a[15][15],f[15],h[5010],dp[15][5010],ans; 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];f[i]=(f[i]<<1)+a[i][j];}dp[0][0]=1;for(int i=0;i<(1<<m);i++)h[i]=((i&(i<<1))==0)&&((i&(i>>1))==0);for(int i=1;i<=n;i++)for(int j=0;j<(1<<m);j++)if(h[j]&&((f[i]&j)==j))for(int k=0;k<(1<<m);k++)if((j&k)==0)dp[i][j]=(dp[i][j]+dp[i-1][k])%P;for(int i=0;i<(1<<m);i++)ans=(ans+dp[n][i])%P;cout<<ans;return 0; } 創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎勵來咯,堅持創(chuàng)作打卡瓜分現(xiàn)金大獎總結(jié)
以上是生活随笔為你收集整理的acwing 327. 玉米田的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 辣条吃了会发胖吗
- 下一篇: [NOIP2016 提高组] 愤怒的小鸟