横竖折对称方阵
#include <stdio.h> // 调用2个头文件 #include <math.h> void main() { int i,j,m,n,a[30][30]; // 定义数据结构 printf(" 请确定方阵阶数(奇数)n: "); scanf("%d",&n); if(n%2==0) { printf(" 请输入奇数!");return;} m=(n+1)/2; for(i=1;i<=n;i++) for(j=1;j<=n;j++) { if(i+j<=n+1 && i<=j || i+j>=n+1 && i>=j) a[i][j]=m-abs(m-j); // 方阵上、下部元素赋值 if(i+j<n+1 && i>j || i+j>n+1 && i<j) a[i][j]=m-abs(m-i); // 方阵左、右部元素赋值 } printf(" %d阶对称方阵为:\n",n); for(i=1;i<=n;i++) { for(j=1;j<=n;j++) // 输出对称方阵 printf("%3d",a[i][j]); printf("\n"); } }