P1231: [Usaco2008 Nov]mixup2 混乱的奶牛

这是一道状压DP,首先这道题让我意识到状态是从 1 to (1<<n)-1 的,所以当前加入的某头牛编号是从 0 to n-1 的,所以存储的时候习惯要改一下,这样子做状压DP才会顺一点吧。

PS:一定要仔细看题目,题目提醒了不会超过64位,然而悲催的没看见,于是第一次就WA了=-=//。

 1 const maxn=1<<16;
 2 var n,i,j,k,max:longint;
 3 ans:int64;
 4 s:array[0..16] of longint;
 5 f:array[0..16,0..maxn] of int64;
 6 begin
 7   readln(n,max);
 8   dec(n);
 9   for i:=0 to n do readln(s[i]);
10   for i:=0 to n do f[i,1<<i]:=1;
11   for i:=0 to 1<<(n+1)-1 do
12     for j:=0 to n do
13       if (i and (1<<j))>0 then
14         for k:=0 to n do
15           if (i and (1<<k)=0) and (abs(s[j]-s[k])>max) then
16             inc(f[k,i or (1<<k)],f[j,i]);
17   for i:=0 to n do
18     inc(ans,f[i,1<<(n+1)-1]);
19   writeln(ans);
20 end.

时间: 2024-10-05 05:05:46

P1231: [Usaco2008 Nov]mixup2 混乱的奶牛的相关文章

1231: [Usaco2008 Nov]mixup2 混乱的奶牛 - BZOJ

Description 混乱的奶牛 [Don Piele, 2007] Farmer John的N(4 <= N <= 16)头奶牛中的每一头都有一个唯一的编号S_i (1 <= S_i <= 25,000). 奶牛为她们的编号感到骄傲, 所以每一头奶牛都把她的编号刻在一个金牌上, 并且把金牌挂在她们宽大的脖子上. 奶牛们对在挤奶的时候被排成一支"混乱"的队伍非常反感. 如果一个队伍里任意两头相邻的奶牛的编号相差超过K (1 <= K <= 3400

[BZOJ1231][Usaco2008 Nov]mixup2 混乱的奶牛

1231: [Usaco2008 Nov]mixup2 混乱的奶牛 Time Limit: 10 Sec  Memory Limit: 162 MB Submit: 1082  Solved: 625 [Submit][Status][Discuss] Description 混乱的奶牛 [Don Piele, 2007] Farmer John的N(4 <= N <= 16)头奶牛中的每一头都有一个唯一的编号S_i (1 <= S_i <= 25,000). 奶牛为她们的编号感到

bzoj1231[Usaco2008 Nov]mixup2 混乱的奶牛(状压dp)

1231: [Usaco2008 Nov]mixup2 混乱的奶牛 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1032  Solved: 588[Submit][Status][Discuss] Description 混乱的奶牛 [Don Piele, 2007] Farmer John的N(4 <= N <= 16)头奶牛中的每一头都有一个唯一的编号S_i (1 <= S_i <= 25,000). 奶牛为她们的编号感到骄傲

[Usaco2008 Nov]mixup2 混乱的奶牛 简单状压DP

1231: [Usaco2008 Nov]mixup2 混乱的奶牛 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 685  Solved: 383[Submit][Status][Discuss] Description 混乱的奶牛 [Don Piele, 2007] Farmer John的N(4 <= N <= 16)头奶牛中的每一头都有一个唯一的编号S_i (1 <= S_i <= 25,000). 奶牛为她们的编号感到骄傲,

BZOJ 1231: [Usaco2008 Nov]mixup2 混乱的奶牛( dp )

状压dp dp( x , S ) 表示最后一个是 x , 当前选的奶牛集合为 S , 则状态转移方程 : dp( x , S ) =  Σ dp( i , S - { i } )  ( i ∈ S , abs( h[ i ] - h[ x ] ) > k ) ------------------------------------------------------------------------------------------- #include<cstdio> #includ

状压DP [Usaco2008 Nov]mixup2 混乱的奶牛

本人水平有限,题解不到为处,请多多谅解 本蒟蒻谢谢大家观看 题目: Problem H: [Usaco2008 Nov]mixup2 混乱的奶牛 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 109  Solved: 59[Submit][Status][Web Board] Description 混乱的奶牛 [Don Piele, 2007] Farmer John的N(4 <= N <= 16)头奶牛中的每一头都有一个唯一的编号S_i (1

【bzoj1231】[Usaco2008 Nov]mixup2 混乱的奶牛

题目描述 混乱的奶牛[Don Piele, 2007]Farmer John的N(4 <= N <= 16)头奶牛中的每一头都有一个唯一的编号S_i (1 <= S_i <= 25,000). 奶牛为她们的编号感到骄傲, 所以每一头奶牛都把她的编号刻在一个金牌上, 并且把金牌挂在她们宽大的脖子上. 奶牛们对在挤奶的时候被排成一支"混乱"的队伍非常反感. 如果一个队伍里任意两头相邻的奶牛的编号相差超过K (1 <= K <= 3400), 它就被称为是

【状压dp】Bzoj1231 [Usaco2008 Nov]mixup2 混乱的奶牛

Description 混乱的奶牛 [Don Piele, 2007] Farmer John的N(4 <= N <= 16)头奶牛中的每一头都有一个唯一的编号S_i (1 <= S_i <= 25,000). 奶牛为她们的编号感到骄傲, 所以每一头奶牛都把她的编号刻在一个金牌上, 并且把金牌挂在她们宽大的脖子上. 奶牛们对在挤奶的时候被排成一支"混乱"的队伍非常反感. 如果一个队伍里任意两头相邻的奶牛的编号相差超过K (1 <= K <= 3400

BZOJ 1231: [Usaco2008 Nov]mixup2 混乱的奶牛

Description 混乱的奶牛 [Don Piele, 2007] Farmer John的N(4 <= N <= 16)头奶牛中的每一头都有一个唯一的编号S_i (1 <= S_i <= 25,000). 奶牛为她们的编号感到骄傲, 所以每一头奶牛都把她的编号刻在一个金牌上, 并且把金牌挂在她们宽大的脖子上. 奶牛们对在挤奶的时候被排成一支"混乱"的队伍非常反感. 如果一个队伍里任意两头相邻的奶牛的编号相差超过K (1 <= K <= 3400