結果
問題 | No.13 囲みたい! |
ユーザー | scache |
提出日時 | 2014-11-12 03:34:21 |
言語 | Java (openjdk 23) |
結果 |
AC
|
実行時間 | 260 ms / 5,000 ms |
コード長 | 1,870 bytes |
コンパイル時間 | 3,108 ms |
コンパイル使用メモリ | 77,872 KB |
実行使用メモリ | 47,024 KB |
最終ジャッジ日時 | 2024-10-13 10:38:51 |
合計ジャッジ時間 | 6,015 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 113 ms
40,152 KB |
testcase_01 | AC | 122 ms
40,932 KB |
testcase_02 | AC | 114 ms
40,024 KB |
testcase_03 | AC | 241 ms
46,456 KB |
testcase_04 | AC | 225 ms
45,968 KB |
testcase_05 | AC | 258 ms
47,024 KB |
testcase_06 | AC | 224 ms
46,292 KB |
testcase_07 | AC | 235 ms
46,664 KB |
testcase_08 | AC | 251 ms
46,840 KB |
testcase_09 | AC | 260 ms
46,312 KB |
testcase_10 | AC | 192 ms
43,056 KB |
testcase_11 | AC | 233 ms
46,380 KB |
testcase_12 | AC | 179 ms
41,972 KB |
testcase_13 | AC | 217 ms
45,368 KB |
testcase_14 | AC | 205 ms
45,440 KB |
testcase_15 | AC | 136 ms
40,996 KB |
ソースコード
import java.util.Arrays; import java.util.LinkedList; import java.util.Scanner; /** * yukicoder no.13 * @author scache * */ public class Main { public static void main(String[] args) { Main p = new Main(); } public Main() { Scanner sc = new Scanner(System.in); int w = sc.nextInt(); int h = sc.nextInt(); int[][] field = new int[h+2][w+2]; for(int i=1;i<=h;i++){ for(int j=1;j<=w;j++){ field[i][j] = sc.nextInt(); } } solve(field); } public void solve(int[][] field) { int[][] visit = new int[field.length][field[0].length]; for(int i=0;i<visit.length;i++) Arrays.fill(visit[i], -1); for(int i=1;i<=field.length-2;i++){ for(int j=1;j<=field[i].length-2;j++){ if(visit[i][j]>=0) continue; visit[i][j] = 0; if(bfs(field, visit, j, i)){ System.out.println("possible"); return; } } } System.out.println("impossible"); } int[] dx = {-1, 0, 1, 0}; int[] dy = {0, 1, 0, -1}; private boolean bfs(int[][] field, int[][] visit, int cx, int cy){ LinkedList<Point> q = new LinkedList<Point>(); LinkedList<Point> from = new LinkedList<Point>(); q.offer(new Point(cx, cy)); from.offer(new Point(cx, cy)); while(!q.isEmpty()){ Point p = q.poll(); Point f = from.poll(); for(int i=0;i<4;i++){ int nx = p.x + dx[i]; int ny = p.y + dy[i]; if(field[p.y][p.x]!=field[ny][nx]) continue; if(visit[ny][nx]>0 && (nx!=f.x || ny!=f.y)){ return true; }else if(visit[ny][nx]<0){ q.offer(new Point(nx, ny)); from.offer(new Point(p.x, p.y)); visit[ny][nx] = visit[p.y][p.x]+1; } } } return false; } private class Point{ public int x; public int y; public Point(int x, int y) { this.x = x; this.y = y; } } }