⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 3554348_wa.java

📁 北大大牛代码 1240道题的原代码 超级权威
💻 JAVA
字号:
import java.util.Arrays;
import java.util.Scanner;

public class Main {
	private Scanner in;
	private int N, C, max, cnt;
	private int[][] triangle;
	private boolean[][] visited;
	private boolean adj;
	private int[][] mov = new int[][] { { 1, 0 }, { 1, 1 }, { 1, -1 },
			{ 0, 1 }, { 0, -1 }, { -1, 1 }, { -1, 0 }, { -1, -1 } };


	public static void main(String[] args) {
		new Main().run();
	}

	private void run() {
		in = new Scanner(System.in);

		while (true) {
			N = in.nextInt();
			C = in.nextInt();
			if (N == 0 && C == 0) {
				break;
			}
			max = Integer.MIN_VALUE;
			triangle = new int[N][];
			visited = new boolean[N][];
			for (int i = 0; i < N; i++) {
				triangle[i] = new int[i + 1];
				visited[i] = new boolean[i + 1];
			}
			for (int i = 0; i < N; i++) {
				for (int j = 0; j < triangle[i].length; j++) {
					triangle[i][j] = in.nextInt();
				}
			}
			for (int i = 0; i < N; i++) {
				for (int j = 0; j < triangle[i].length; j++) {
					if (triangle[i][j] == 0) {
						triangle[i][j] = C;
						int score = calcScore();
						if (score > max) {
							max = score;
						}
						triangle[i][j] = 0;
					}
				}
			}
			System.out.println(max);
		}

	}

	private int calcScore() {
		int ret = 0;

		for (int i = 0; i < N; i++) {
			Arrays.fill(visited[i], false);
		}
		for (int i = 0; i < N; i++) {
			for (int j = 0; j < triangle[i].length; j++) {
				if (triangle[i][j] != 0 && !visited[i][j]) {
					adj = false;
					cnt = 0;
					floodFill(i, j);
					if (adj) {
						continue;
					}
					if (triangle[i][j] == C) {
						ret -= cnt;
					} else {
						ret += cnt;
					}
				}
			}
		}
		return ret;
	}

	private void floodFill(int i, int j) {
		visited[i][j] = true;
		cnt++;

		for (int l = 0; l < mov.length; l++) {
			int x = i + mov[l][0];
			int y = j + mov[l][1];
			if (!valid(x, y) || visited[x][y]) {
				continue;
			}
			if (triangle[x][y] == 0) {
				adj = true;
			} else {
				if (triangle[x][y] == triangle[i][j]) {
					floodFill(x, y);
				}
			}
		}

	}

	private boolean valid(int i, int j) {
		if (i >= N || i < 0 || j >= triangle[i].length || j < 0) {
			return false;
		}
		return true;
	}

}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -