凳子377 2021-11-30 10:53 采纳率: 100%
浏览 24
已结题

输入奇数 产出奇数阶的幻方,但是我的程序运行之后总是出错 望大家解答一下

#include <stdio.h>
int main(void)
{
int m,l,p,n,i,j;
printf("This program creates a magic square of a specified size.\n");
printf("The size must be an odd number between 1 and 99.\n");
printf("Enter size of magic square: ");
scanf("%d",&n);
int a[n][n];
for (i=0;i<n;i++){
for (j=0;j<n;j++)
a[i][j]=0;
}
l=n / 2;
a[0][l]=1;
m=n * n;
for (i=n-1;1;i--){
if (i==-1)
i=n - 1;
for (j=l+1;1;j++){
if (j==n)
j=0;
for (p=2;p<=m;p++){
if (a[i][j]==0){
a[i][j]=p;
}
else{
i=i + 2;
j=j - 1;
a[i][j]=p;
}
}
}
}
for (i=0;i<n;i++){
for (j=0;j<=n;j++){
if (j==n)
printf("\n");
else
printf("%d",a[i][j]);
}
}
return 0;
}

  • 写回答

2条回答 默认 最新

  • 南七灵 2021-11-30 11:10
    关注

    帮你找个能用的,自己对比着看看

    #include <stdio.h>
    int main()
    {
        int i,j, n, k = 1;
        scanf("%d", &n);
        int a[n][n];
        for (i = 0; i < n; i++)
            for (j = 0; j < n; j++)
                a[i][j] = 0;
        a[i = 0][j = n / 2] = k;
        for (k = 2; k <= n * n; k++)
        {
            i -= 1;
            j += 1;
            if (i == -1 && j != n)
            {
                i = n - 1;
                a[i][j] = k;
            }
            else if (j == n && i != -1)
            {
                j = 0;
                a[i][j] = k;
            }
            else if ((i == -1 && j == n) || a[i][j] != 0)
            {
                i += 2;
                j -= 1;
                a[i][j] = k;
            }
            else
                a[i][j] = k;
        }
        
        for (i = 0; i < n; i++)
        {
            for (j = 0; j < n; j++)
                printf("%3d", a[i][j]);
            printf("\n");
        }
        printf("\n");
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 12月5日
  • 已采纳回答 12月5日
  • 创建了问题 11月30日

悬赏问题

  • ¥20 完全没有学习过GAN,看了CSDN的一篇文章,里面有代码但是完全不知道如何操作
  • ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
  • ¥20 软件测试决策法疑问求解答
  • ¥15 win11 23H2删除推荐的项目,支持注册表等
  • ¥15 matlab 用yalmip搭建模型,cplex求解,线性化处理的方法
  • ¥15 qt6.6.3 基于百度云的语音识别 不会改
  • ¥15 关于#目标检测#的问题:大概就是类似后台自动检测某下架商品的库存,在他监测到该商品上架并且可以购买的瞬间点击立即购买下单
  • ¥15 神经网络怎么把隐含层变量融合到损失函数中?
  • ¥15 lingo18勾选global solver求解使用的算法
  • ¥15 全部备份安卓app数据包括密码,可以复制到另一手机上运行