编写一个程序,检查二维整数数组是否为方形数组,也就是说,它的行和列是否相等.我的代码在下面


package Homeworks;
public class HomeWork85 {
public static void main(String[] args) {

int[][] a = {
{1,1,1,2},
{1,1,1},
{1,1,1}
};
int[][] b = {
{1,1,1,1},
{1,1,1,1},
{1,1,1,1}
};
for (int i=0; i<a.length;i++) {
for (int j=0;j<a[i].length-1;j++) {
if (a.length==a[j].length) {
System.out.println("It is a square");
}else {
System.out.println("Not a square");
}
}
}
}
}

尽管您的逻辑是正确的,但您正在进行冗余检查。理想情况下,您应该使用a.length来获得行长度。您应该使用a[j].length对每一行进行一次迭代,并检查行数是否等于每一行中的值数(列数(。

如果不是,则打印"非正方形"并脱离循环。保留一个标志,指示循环已明确停止。如果不是,旗帜保持不变,你可以得出结论,它是一个正方形。

int flag = 0;
for (int j=0;j<a.length;j++) {
if (a.length != a[j].length){
System.out.println("Not a Square!");
flag = 1;
break;
}
}   
if (flag == 0){
System.out.println("It is a Square");
}

最新更新