日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

填涂颜色(洛谷P1162题题解,Java语言描述)

發布時間:2025/3/15 java 15 豆豆
生活随笔 收集整理的這篇文章主要介紹了 填涂颜色(洛谷P1162题题解,Java语言描述) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題目要求

題目鏈接

分析

這個題,很難直接確定那里是1這個邊界并找到內部的0的,想想就很難受。

但是數學上有個思想叫 “正難則反” 不是嗎?

我們不妨把所有0換成2,再從四條邊上的每個點開DFS,把搜到的2全換成0,這種DFS不可能搜到內部的2(被一圈1圍著),如此,巧妙的規避了“圈內”這個復雜的條件,簡化了問題求解。

注意防越界!

AC代碼(Java語言描述)

import java.util.Scanner;public class Main {private static int num;private static byte[][] array;private static void dfs(int x, int y) {if (array[x][y] == 1) {return;} else {array[x][y] = 0;}if (x > 0 && array[x-1][y] == 2) {dfs(x-1, y);}if (x < num-1 && array[x+1][y] == 2) {dfs(x+1, y);}if (y > 0 && array[x][y-1] == 2) {dfs(x, y-1);}if (y < num-1 && array[x][y+1] == 2) {dfs(x, y+1);}}public static void main(String[] args) {Scanner scanner = new Scanner(System.in);num = Integer.parseInt(scanner.nextLine());array = new byte[num][num];for (int i = 0; i < num; i++) {String[] line = scanner.nextLine().split(" ");for (int j = 0; j < num; j++) {if ("0".equals(line[j])) {array[i][j] = 2;} else {array[i][j] = Byte.parseByte(line[j]);}}}scanner.close();for (int i = 0; i < num; i++) {dfs(i, 0);dfs(i, num-1);dfs(0, i);dfs(num-1, i);}for (int i = 0; i < num; i++) {StringBuilder builder = new StringBuilder();for (int j = 0; j < num; j++) {builder.append(array[i][j]).append(' ');}System.out.println(builder.toString().trim());}}}

總結

以上是生活随笔為你收集整理的填涂颜色(洛谷P1162题题解,Java语言描述)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。