我们这个实验目的是实现大于2的奇数的n阶幻方
根据上述的例子我们可以看到一些规律,显示1放在最上方中间的位置,然后向右上方延申,在达到n这个数字时,停止延申,然后在n的下方开始n+1的新一轮延申。明白了原理之后就很容易使用代码实现这个实验了。
#include <iostream>
using namespace std;int main()
{int n, i = 0, j = 0, k = 1, s = 0, arr[99][99] = { 0 };//n是我们需要的奇数//i是用来循环的,同样也是数组一维的下标//j是在数组二维中的下标// k是我们以此镶入数组的数字//s是n的阶乘//arr是用来存储得到的幻方cout << "请输入一个大于2的奇数" << endl;cin >> n;j = (n - 1) / 2;s = n * n;arr[i][j] = k;//这是将1放在中间k++;while (s > 1){if (i == 0 && j != n - 1){i = n - 1;j += 1;arr[i][j] = k;k++;}else if (i != 0 && j == n - 1){i -= 1;j = 0;arr[i][j] = k;k++;}else if (i == 0 && j == n - 1 || arr[i-1][j+1] != 0 )//前者是因为到了幻方的右上角无法直接判断是否循环到头,后者是可以判断一次的循环已经到头了,该换到下一列到第二次循环了{i += 1;arr[i][j] = k;k++;}else {i -= 1;j += 1;arr[i][j] = k;k++;}s--;//用于判定整体循环何时结束}for (i = 0; i < n; i++) {for (j = 0; j < n; j++)cout << arr[i][j] << " ";cout << endl;}return 0;
}
可以 正确输出结果了