BZOJ 1087 互不侵犯King

2021-07-22 01:52:35 字數 1047 閱讀 4904

1087: [scoi2005]互不侵犯king

time limit: 10 sec memory limit: 162 mb

description

在n×n的棋盤裡面放k個國王,使他們互不攻擊,共有多少種擺放方案。國王能攻擊到它上下左右,以及左上

左下右上右下八個方向上附近的各乙個格仔,共8個格仔。

input

只有一行,包含兩個數n,k ( 1 <=n <=9, 0 <= k <= n * n)

output

方案數。

sample input

3 2

sample output

這道題就是hdu的加強版。。。仍然是用狀態壓縮來做。

在基礎上增加一維來移動就ok啦!

不懂的就去看一下我前一篇部落格吧ywy

傳送門:

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

using

namespace

std;

typedef

long

long ll;

int bit[110],num[1

<<9+10];

ll f[110][(1

<<9)+10][110];

int v[(1

<<9)+10],vn;

int main()

}f[1][x][tmp]=1;

num[vn]=tmp;}}

for(int i=2;i<=n;i++)}}

}}

ll ans=0;

for(int i=1;i<=vn;i++) ans+=f[n][v[i]][m];

printf("%lld\n",ans);

return

0;}

BZOJ 1087, 互不侵犯

傳送門 給定一張大小為n n的棋盤,要求放置k個棋子,其中,棋子上下左右以及左上 左下 右上和右下八個位置不得有其它棋子存在。求合法方案數。動態規劃。狀態數很多,可以先預處理出一行的合法放置方案,再處理出上一行放置的情況下,下一行哪些方案是可行的,於是一行一行轉移即可。運用位運算優化預處理,後來四重...

BZOJ 1087( ) 互不侵犯

1087 scoi2005 互不侵犯king time limit 10 sec memory limit 162 mb submit 5333 solved 3101 submit status discuss description 在n n的棋盤裡面放k個國王,使他們互不攻擊,共有多少種擺放方...

BZOJ 1087 互不侵犯King

time limit 10 sec memory limit 162 mb submit 4064 solved 2354 submit status discuss 在n n的棋盤裡面放k個國王,使他們互不攻擊,共有多少種擺放方案。國王能攻擊到它上下左右,以及左上 左下右上右下八個方向上附近的各乙...