【蓝桥杯】最大连通分块--Java

该文章介绍了一个使用深度优先搜索(DFS)解决的问题,即在给定的30x60二进制矩阵中找到最大的连通分块。当矩阵中的数字为1时,如果可以从一个1移动到另一个1(上下左右),则认为它们是连通的。程序通过DFS遍历矩阵并使用一个额外的二维数组进行标记,避免重复计算,最终找出并返回最大的连通分块的大小,这里是148。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述:

小蓝有一个 30 行 60 列的数字矩阵,矩阵中的每个数都是 0 或 1 。

110010000011111110101001001001101010111011011011101001111110
010000000001010001101100000010010110001111100010101100011110
001011101000100011111111111010000010010101010111001000010100
101100001101011101101011011001000110111111010000000110110000
010101100100010000111000100111100110001110111101010011001011
010011011010011110111101111001001001010111110001101000100011
101001011000110100001101011000000110110110100100110111101011
101111000000101000111001100010110000100110001001000101011001
001110111010001011110000001111100001010101001110011010101110
001010101000110001011111001010111111100110000011011111101010
011111100011001110100101001011110011000101011000100111001011
011010001101011110011011111010111110010100101000110111010110
001110000111100100101110001011101010001100010111110111011011
111100001000001100010110101100111001001111100100110000001101
001110010000000111011110000011000010101000111000000110101101
100100011101011111001101001010011111110010111101000010000111
110010100110101100001101111101010011000110101100000110001010
110101101100001110000100010001001010100010110100100001000011
100100000100001101010101001101000101101000000101111110001010
101101011010101000111110110000110100000010011111111100110010
101111000100000100011000010001011111001010010001010110001010
001010001110101010000100010011101001010101101101010111100101
001111110000101100010111111100000100101010000001011101100001
101011110010000010010110000100001010011111100011011000110010
011110010100011101100101111101000001011100001011010001110011
000101000101000010010010110111000010101111001101100110011100
100011100110011111000110011001111100001110110111001001000111
111011000110001000110111011001011110010010010110101000011111
011110011110110110011011001011010000100100101010110000010011
010011110011100101010101111010001001001111101111101110011101

如果从一个标为 1 的位置可以通过上下左右走到另一个标为 1 的位置,则称两个位置连通。与某一个标为 1 的位置连通的所有位置(包括自己)组成一个连通分块。请问矩阵中最大的连通分块有多大?


思路:dfs遍历二维数组,并且当值是1的时候创建一个二维数组来进行标记以免重复计入。

代码:

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        int[][] num = new int[30][60];//装数据
        int[][] flag = null;//用于标记
        for (int i = 0; i < 30; i++) {
            String s = scan.nextLine();
            for (int j = 0; j < 60; j++) {
                num[i][j] = s.charAt(j)-'0';
            }
        }
        int count = 0;//记录最大连通分块大小
        for (int i = 0; i < 30; i++) {
            for (int j = 0; j < 60; j++) {
                if(num[i][j]==1){
                    flag = new int[30][60];//创建一个新的二维数组进行标记
                    int t = dfs(num,i,j,flag);
                    if(count<t){
                        count = t;
                    }
                }
            }
        }
        System.out.println(count);
    }

    private static int dfs(int[][] num, int i, int j, int[][] flag) {
        if(i<0||i>=30||j<0||j>=60||num[i][j]==0||flag[i][j]!=0) return 0;
        flag[i][j]++;//表示该位置是1且已被记入。
        return 1+dfs(num,i+1,j,flag)+dfs(num,i-1,j,flag)
            +dfs(num,i,j+1,flag)+dfs(num,i,j-1,flag);
    }
}

结果:148


评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值