剛開始用java寫東西,歡迎指點。
1.Scanner位於java.util.*內
2.java的String類不像c++內的string。影響到資料輸入和雜湊。
其他總的來說還算適應。
import java.util.*;<br />public class Main {<br />/**<br /> * @param args<br /> */<br />static int n , m;<br />static final int MaxN = 101;<br />static char map[][] = new char[MaxN][MaxN];<br />static int dir[][] = {{0 , 1},{0 , -1},{-1 , 0},{1 , 0},{1 , 1},{-1 , -1},{-1 , 1},{1 , -1}};</p><p>static boolean inMap(int r ,int c){<br />return r >= 0 && c >= 0 && r < n && c < m;<br />}</p><p>static void DFS(int r ,int c){<br />map[r][c] = '*';<br />int _r , _c , i;<br />for (i = 0;i < 8;i ++){<br />_r = r + dir[i][0];<br />_c = c + dir[i][1];<br />if (inMap(_r , _c) && map[_r][_c] == '@'){<br />DFS(_r , _c);<br />}<br />}<br />}</p><p>public static void main(String[] args) {<br />// TODO Auto-generated method stub<br />int i , j , cnt;<br />String a = new String();<br />Scanner in = new Scanner(System.in);<br />while (true){<br />n = in.nextInt();<br />m = in.nextInt();<br />if (n == 0 && m == 0)break;<br />for (i = 0;i < n;i ++){<br />a = in.next();<br />map[i] = a.toCharArray();<br />}<br />for (cnt = i = 0;i < n;i ++){<br />for (j = 0;j < m;j ++){<br />if (map[i][j] == '@'){<br />cnt ++;<br />DFS(i , j);<br />}<br />}<br />}<br />System.out.println(cnt);<br />}</p><p>}<br />}<br />