Java:从给定元素开始,在2d数组中找到具有相同值的所有相邻元素

时间:2016-07-12 21:21:18

标签: java search recursion multidimensional-array nearest-neighbor

我正在开发一个包含2维16x32字符数组的程序。我想要做的是,从这个数组中的给定元素开始,找到所有共享相同值的元素(在我的例子中是一个空格''),并且水平和/或垂直链接到彼此。

我正在使用的方法存储它在另一个数组中找到的索引,称为 toShow public static int toShow[][] = new int[30][30];)。问题是这种方法似乎没有向右侧进行处理。奇怪的是,它似乎在另一方面起作用......这是一个例子:

X1    123
31     1X
211    24
1X1  112X
111 12X34
111•2X32X
1X113X211

在这种情况下,从标记为•的元素开始,该方法应该存储每个''字符和所有邻居数字......但这是结果:

1••
1••
 1•
 1•
 1•
 1•

然而,如果从左下角开始,它通常会起作用,即使它必须向右转!

我不明白我的代码有什么问题...无论如何这里是奇怪的方法:

public static void getEmptySurrounding(int xcoord, int ycoord) {
    if (toShow[xcoord][ycoord] == 1) {
        return;
    }

    else {
        toShow[xcoord][ycoord] = 1;
    }

    //DOWN
    if((ycoord!=29) && ycoord + 1 < 16) {
        if (board[xcoord][ycoord] == ' ') {
            getEmptySurrounding(xcoord, ycoord + 1);
        }
    }
    //RIGHT
    if((xcoord!=15) && xcoord + 1 < 30) {
        if (board[xcoord][ycoord] == ' ') {
            getEmptySurrounding(xcoord + 1, ycoord);
        }
    }
    //UP
    if((ycoord!=0) && ycoord - 1 >= 0) {
        if (board[xcoord][ycoord] == ' ') {
            getEmptySurrounding(xcoord, ycoord - 1);
        }
    }
    //LEFT
    if((xcoord!=0) && xcoord - 1 >= 0) {
        if (board[xcoord][ycoord] == ' ') {
            getEmptySurrounding(xcoord - 1, ycoord);
        }
    }   
}

谢谢!

1 个答案:

答案 0 :(得分:0)

根据您提供的信息,我提出了一个测试方法的应用程序:

public class Mine {

    private static char board[][] = new char[16][32];
    private static int toShow[][] = new int[30][30];

    public static void main(String[] args) {
        int n = 0;
        insert(n++, "X1    123");
        insert(n++, "31     1X");
        insert(n++, "211    24");
        insert(n++, "1X1  112X");
        insert(n++, "111 12X34");
        insert(n++, "111 2X32X");
        insert(n++, "1X113X211");

        getEmptySurrounding(3, 5);

        for (int i = 0; i < 30; i++) {
            for (int j = 0; j < 30; j++) {
                System.out.print(toShow[j][i]);
            }
            System.out.println();
        }
    }

    public static void getEmptySurrounding(int xcoord, int ycoord) {
        if (toShow[xcoord][ycoord] == 1) {
            return;
        }

        else {
            toShow[xcoord][ycoord] = 1;
        }

        // DOWN
        if ((ycoord != 29) && ((ycoord + 1) < 16)) {
            if (board[xcoord][ycoord] == ' ') {
                getEmptySurrounding(xcoord, ycoord + 1);
            }
        }
        // RIGHT
        if ((xcoord != 15) && ((xcoord + 1) < 30)) {
            if (board[xcoord][ycoord] == ' ') {
                getEmptySurrounding(xcoord + 1, ycoord);
            }
        }
        // UP
        if ((ycoord != 0) && ((ycoord - 1) >= 0)) {
            if (board[xcoord][ycoord] == ' ') {
                getEmptySurrounding(xcoord, ycoord - 1);
            }
        }
        // LEFT
        if ((xcoord != 0) && ((xcoord - 1) >= 0)) {
            if (board[xcoord][ycoord] == ' ') {
                getEmptySurrounding(xcoord - 1, ycoord);
            }
        }
    }

    public static void insert(int n, String a) {
        for (int i = 0; i < 16; i++) {
            board[i][n] = a.length() <= i ? ' ' : a.charAt(i);
        }
    }

}

最后打印出toShow的内容,相关部分为:

011111100000000000000000000000
011111110000000000000000000000
001111110000000000000000000000
001111100000000000000000000000
001110000000000000000000000000
001110000000000000000000000000
000100000000000000000000000000
000000000000000000000000000000
000000000000000000000000000000
000000000000000000000000000000

表明该方法可以正常工作。

所以可能问题出在你的程序的其他地方。