HDU1241油田

static int n;
	static int m;
	static char str[][] = new char[101][101];
	static int count;
	public static void main(String[] args) {
		Scanner cin = new Scanner(System.in);
		while(cin.hasNextInt()){
			n = cin.nextInt();
			m = cin.nextInt();
			if(n==0||m==0) break;
			str = new char[n][m];
			for (int i = 0; i < n; i++) {
				String string = cin.next();
				for (int j = 0; j < string.length(); j++) {
					str[i][j] = string.charAt(j);
					
				}
			}
			
			count = 0;
			for (int i = 0; i < n; i++) {
				for (int j = 0; j < m; j++) {
					if(str[i][j]=='@') {
						count++;
						DFS(i,j);
						
					}
				}
			}
			System.out.println(count);
			
			
		}
	}
	private static void DFS(int x, int y) {
		
		if(x<0 || y<0 || x>=n || y>=m) return; //到达边界了 
		
		if(str[x][y]=='@') {
			str[x][y]='*';
		for (int i = -1; i <=1; i++) {
			for (int j = -1; j <=1; j++) {
					if(i!=0||j!=0){
						DFS(x+i,y+j);
					}
				}
			}
		}
	}

猜你喜欢

转载自blog.csdn.net/fly_eason/article/details/79716265