magic square java_测试Magic Square Java的.txt文件

我不想问,但我无法弄清楚这个任务,当我寻求帮助时,助教也不会。

我必须从文本文件中获取输入,将文件中的整数输入到数组列表中,然后测试它是否是anxn幻方。n等于数组列表长度的平方根。如果不是理想的正方形,它将立即无法通过魔方测试。

无论如何我都快完成了;我似乎不明白我的教授在魔方测试的最后一步告诉/要求我们做什么。

最后这四个步骤之前的所有测试都可以正常进行。在步骤之后,我将发布当前代码。

4.

假设rowSums和colSums是长度为n的两个数组,其条目均为零。另外,让sumDiagMajor和sumDiagMinor分别代表表的左上角到右下角和右上角到左下角的条目的总和。

设索引= 0

重复直到index = n2(a)将ArrayList {index}增加rowSums [row](b)将ArrayList

{index}增加colSums [col](c)如果row = col,则将sumDiagMajor增加ArrayList

{index}。(d)如果row + col = n-1,则将sumDiagMinor增加ArrayList {index}(e)将索引增加1

如果sumDiagMajor等于sumDiagMinor以及rowSums和colSums的每个条目,则该表是一个魔方;否则,事实并非如此。

int rowSums[] = new int[_n];

int colSums[] = new int[_n];

int sumDiagMajor = 0;

int sumDiagMinor = 0;

int row, col;

row = col = 0;

for (int index = 0; index < (n*n); index++)

{

rowSums[row] = rowSums[row] + magicSquare.get(index);

colSums[col] = colSums[col] + magicSquare.get(index);

if (row == col)

{

sumDiagMajor = sumDiagMajor + magicSquare.get(index);

}

if ((row + col) == (n - 1))

{

sumDiagMinor = sumDiagMinor + magicSquare.get(index);

}

}

System.out.println(sumDiagMajor);

System.out.println(sumDiagMinor);

我的问题包括,是否可以适当增加数组rowSums和rowCols?他从未真正说明过要处理行或列,所以将它们初始化为零是最好的选择吗?

如果到目前为止我所做的一切都正确,那么sumDiagMajor永远等于sumDiagMinor,因为行将始终等于cols,因此第二个嵌套的if语句将永远不会运行。因此,它将排除所有测试是否是魔方?

抱歉,很长的帖子,但这很令人困惑。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值