横竖折对称方阵

 

#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");
        }
 }

 

 

posted on 2017-11-29 22:56  小星_log  阅读(359)  评论(0编辑  收藏  举报