繁体   English   中英

如何在java中反转布尔数组?

[英]How do I reverse a boolean array in java?

我想反转一个布尔数组。 free是数组。 这是我的代码:

public boolean[][] free = new boolean[6][6];

free = !free;

我收到一个错误说操作员! 未定义。 我该怎么办?

编辑它不是空的。 我只想反转这些值。

public boolean[][] free = new boolean[6][6];
    void initFree(State s) {

        for (int i = 0; i < nbcars; i++){
            if (horiz[i]){

                for (int j = 0; j < (len[i]-1); j++)        
                    free[moveon[i]][s.pos[i]+j]=true;


            }
            if (!horiz[i]){

                for (int j = 0; j < (len[i]-1); j++)        
                    free[s.pos[i]+j][moveon[i]]=true;
            }
        }
        free = !free;
    }

你得到运营商! 未定义仅仅是因为 Java 没有定义 ! 二维布尔数组上的运算符。

您可以实现所需的一种方法是迭代每个值,然后使用 ! 操作员。

for(int i=0; i<free.length; i++) 
{
    for(int j=0; j<free[i].length; j++) 
    {
        free[i][j] != free[i][j];
    }
}

这是一个简单的示例,您可以根据自己的用途进行修改。 我包括了一个反转方法。

public class StackOverflowExample {

public static void main(String[] args) {
    int ROW = 10, COL = 10;
    boolean[][] ATwoDBoolArray = new boolean[ROW][COL];

    PutValuesInArray(ATwoDBoolArray);
    printArray(ATwoDBoolArray);
    invertArray(ATwoDBoolArray);
    printArray(ATwoDBoolArray);

}

private static boolean[][] PutValuesInArray(boolean array[][]) {

    for (int i = 0; i < array.length; i++) {
        for (int j = 0; j < array[i].length; j++) {
            array[i][j] = false;

        }

    }

    return array;
}

private static void printArray(boolean[][] array){
    for (int i = 0; i < array.length; i++) {
        for (int j = 0; j < array[i].length; j++) {
            System.out.println(array[i][j]);

        }

    }

}

private static boolean[][] invertArray(boolean array[][]){
    for (int i = 0; i < array.length; i++) {
        for (int j = 0; j < array[i].length; j++) {
            if(array[i][j]){
                array[i][j] = false;

            }else{
                array[i][j] = true;

            }

        }

    }


    return array;
}

}

此方法反转给定二维布尔数组中的所有值。

static void invertBooleanArray(boolean[][] arr) {
    for (int i = 0; i < arr.length; i++)
        for (int j = 0; j < arr[0].length; j++)
            arr[i][j] = !arr[i][j];
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM