我不想問,但我無法弄清楚這個任務,當我尋求幫助時,助教也不會。
我必須從文本文件中獲取輸入,將文件中的整數輸入到數組列表中,然后測試它是否是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語句將永遠不會運行。因此,它將排除所有測試是否是魔方?
抱歉,很長的帖子,但這很令人困惑。