二维数组相关问题—黑白棋子替换

本文介绍了一种算法,用于在二维矩阵式的棋盘上查找被黑色棋子完全包围的白色棋子,并将其替换为黑色棋子。示例展示了如何通过正向和反向遍历矩阵来实现这一目标,确保边界上的白色棋子不会被替换。

题目描述: 假设有个二维矩阵式的棋盘,包含黑白两种颜色的棋子,分别用字母“X”和“O”表示,找到 所有被黑色棋子“X”围绕的白色棋子“O”,并将其替换成黑色棋子。

示例:

X X X X

X O O X

X X O X

X O X X

函数运行后,输出如下:

X X X X

X X X X

X X X X

X O X X

注意事项:任何边界上的白色棋子都不会置换成黑色棋子。

public static char[][] replace(char[][] in) {
        int row=in.length;
        int col = in[0].length;
//用来记录数组中哪些字符修改过,若改过,记录为true,否则为false。
        boolean[][] flag=new boolean[row][col];
//正向遍历in[1][1]到in[row-2][col-2]之间的字符
        for (int i = 1; i < row-1; i++) {
            for (int j = 1; j < col-1; j++) {
//如果当前位置为O,并且左边、上边为X,此位置变为X,flag[i][j]=true,且表示修改过值
                
                if (in[i][j]=='O'&&in[i-1][j]=='X'&&in[i][j-1]=='X') {
                    in[i][j]='X';
                    flag[i][j]=true;
                }
            }
        }
//反向遍历从in[row-2][col-2]到in[1][1]之间的字符
        for (int i = row-2; i >0; i--) {
            for (int j = col-2; j>0; j--) {
//如果当前位置的值改过,且右边、下边任一位置的值为'O',则此位置设为'O'
                
                if ((in[i+1][j]=='O'||in[i][j+1]=='O')&&flag[i][j]==true)
                {
                    in[i][j]='O';
                }
            }
        }
        return in;
    }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值