#include<stdio.h> int A[101][101]; void guiling() { for(int i=1;i<=10;i++) { for(int j=1;j<=10;j++) { A[i][j]=0; } } } void shuchu(int a) { for(int i=1;i<=a;i++) for(int j=1;j<=a;j++) { printf("%4d ",A[i][j]); if(j==a) { printf("\n"); } } printf("\n"); guiling(); } void jishu(int a) { A[1][(a+1)/2]=1; int a1=1,b1=(a+1)/2; int a2,b2; for(int k=2;k<=a*a;k++) { a2=a1,b2=b1; if(--a1==0) a1=a; if(++b1>a) b1=1; if(A[a1][b1]!=0) { a1=a2+1; if(a1>a) { a1=1; } b1=b2; } A[a1][b1]=k; } shuchu(a); } //void Kjie(int a,int b) //{ // // // //} // //void jie(int a,int b) //{ // // // //} void panduan() { for(int i=3;i<11;i++) { for(int j=3;j<11;j++) { if((i-1)%2==0&&i==j) { jishu(j); } // if(i%2==0&&i==j&&i!=6&&i!=10) // { // Kjie(i,j); // } // // if((i==6||i==10)&&i==j) // { // jie(i,j); // } } } } int main() { guiling(); panduan(); return 0; }
时间: 2024-04-25 15:27:14 浏览: 166
这段代码是用来生成幻方的,幻方是一个 n x n 的矩阵,其中每行、每列和每条对角线上的元素之和都相等。这里实现的是奇数阶幻方,即 n 为奇数。代码中的函数 guiling() 是用来初始化矩阵的,shuchu() 是用来输出矩阵的,jishu() 是用来生成奇数阶幻方的。panduan() 函数是用来检查生成的幻方是否正确的,其中只实现了生成奇数阶幻方的部分。如果需要生成偶数阶幻方以及更高阶的幻方,可以在代码中添加相应的函数实现。
阅读全文