BZOJ 1088 扫雷Mine 枚举初始状态
题目链接:
https://www.lydsy.com/JudgeOnline/problem.php?id=1088
题目大意:
现在棋盘是n×2的,第一列里面某些格子是雷,而第二列没有雷,如下图: 由于第一列的雷可能有多种方案满足第二列的数的限制,你的任务即根据第二列的信息确定第一列雷有多少种摆放方案。
思路:
只需要枚举第一行是否有雷就ok了。
判断的时候除了判断相等,还要判断每a个f[i]范围必须在0-1之间
1 #include<bits/stdc++.h> 2 #define IOS ios::sync_with_stdio(false);//不可再使用scanf printf 3 #define Max(a, b) ((a) > (b) ? (a) : (b))//禁用于函数,会超时 4 #define Min(a, b) ((a) < (b) ? (a) : (b)) 5 #define Mem(a) memset(a, 0, sizeof(a)) 6 #define Dis(x, y, x1, y1) ((x - x1) * (x - x1) + (y - y1) * (y - y1)) 7 #define MID(l, r) ((l) + ((r) - (l)) / 2) 8 #define lson ((o)<<1) 9 #define rson ((o)<<1|1) 10 #define Accepted 0 11 #pragma comment(linker, "/STACK:102400000,102400000")//栈外挂 12 using namespace std; 13 inline int read() 14 { 15 int x=0,f=1;char ch=getchar(); 16 while (ch<'0'||ch>'9'){if (ch=='-') f=-1;ch=getchar();} 17 while (ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();} 18 return x*f; 19 } 20 21 typedef long long ll; 22 const int maxn = 10000 + 10; 23 const int MOD = 1000000007;//const引用更快,宏定义也更快 24 const int INF = 1e9 + 7; 25 const double eps = 1e-6; 26 int a[maxn]; 27 int f[maxn];//f[i]表示i是否有雷 28 int n; 29 bool judge() 30 { 31 for(int i = 2; i <= n; i++)f[i] = a[i - 1] - f[i - 1] - f[i - 2]; 32 for(int i = 1; i <= n; i++) 33 { 34 if(a[i] != f[i - 1] + f[i] + f[i + 1] || f[i] < 0 || f[i] > 2)return false; 35 } 36 return true; 37 } 38 int main() 39 { 40 cin >> n; 41 for(int i = 1; i <= n; i++)scanf("%d", &a[i]); 42 int ans = 0; 43 f[1] = 0;//枚举第一行 44 if(judge())ans++; 45 Mem(f); 46 f[1] = 1; 47 if(judge())ans++; 48 cout<<ans<<endl; 49 return Accepted; 50 }
越努力,越幸运