2015 百度之星 1003 棋盘占领 dfs
棋盘占领
Time Limit: 20 Sec Memory Limit: 256 MB
题目连接
http://bestcoder.hdu.edu.cn/contests/contest_showproblem.php?cid=601&pid=1003
Description
Input
第一行为T,表示输入数据组数。
下面T组数据,对于每组数据, 第一行是两个数n,m(1≤n,m≤500),表示国土的大小为n*m。
第二行是一个整数g(1≤g≤1000),表示我们一开始占领的城池数。 然后跟随g行,第i行一对整数x,y(1≤x≤n,1≤y≤m),表示占领的第i个城池的坐标。
下面T组数据,对于每组数据, 第一行是两个数n,m(1≤n,m≤500),表示国土的大小为n*m。
第二行是一个整数g(1≤g≤1000),表示我们一开始占领的城池数。 然后跟随g行,第i行一对整数x,y(1≤x≤n,1≤y≤m),表示占领的第i个城池的坐标。
Output
对第i组数据,输出
Case #i:
然后输出一行,仅包含一个整数,表示最终有多少个城池被占领。
Sample Input
4 2 2 2 1 1 2 2 3 3 3 1 1 2 3 3 2 2 4 5 1 1 1 1 1 2 1 3 1 4 2 4 2 1 1 2 4
Sample Output
Case #1: 4 Case #2: 9 Case #3: 4 Case #4: 2
HINT
题意
题解:
直接暴力修改就好,这份代码是kuangbin的,我看不了我的代码 = =
我是dfs修改的,和某次cf的题很类似
代码:
#include <stdio.h> #include <string.h> #include <iostream> #include <algorithm> #include <vector> #include <queue> #include <set> #include <map> #include <string> #include <math.h> #include <stdlib.h> #include <time.h> using namespace std; bool f[550][550]; int main() { //freopen("in.txt","r",stdin); //freopen("out.txt","w",stdout); int T; int n,m; int iCase = 0; scanf("%d",&T); while(T--){ iCase++; scanf("%d%d",&n,&m); memset(f,false,sizeof(f)); int x,y; int g; scanf("%d",&g); while(g--){ scanf("%d%d",&x,&y); x--; y--; f[x][y] = true; } while(1){ bool add = false; for(int i = 0;i < n;i++) for(int j = 0;j < m;j++){ if(f[i][j])continue; if(i > 0 && j < m-1 && f[i-1][j] && f[i][j+1]){ f[i][j] = true; add = true; continue; } if(i > 0 && j > 0 && f[i-1][j] && f[i][j-1]){ f[i][j] = true; add = true; continue; } if(i < n-1 && j > 0 && f[i+1][j] && f[i][j-1]){ f[i][j] = true; add = true; continue; } if(i < n-1 && j < m-1 && f[i+1][j] && f[i][j+1]){ f[i][j] = true; add = true; continue; } } if(!add)break; } int ans = 0; for(int i = 0;i < n;i++) for(int j = 0;j < m;j++) ans += f[i][j]; printf("Case #%d:\n%d\n",iCase,ans); } return 0; }