社区讨论

60分不明为何RE 求助大佬

P2615[NOIP 2015 提高组] 神奇的幻方参与者 2已保存回复 5

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
5 条
当前快照
1 份
快照标识符
@mi6lj3n0
此快照首次捕获于
2025/11/20 06:50
4 个月前
此快照最后确认于
2025/11/20 06:50
4 个月前
查看原帖
我觉得我的程序还是很好理解的,直接按题目的打的啊怎么都会错!!!
程序:
CPP
#include<cmath>
#include<iostream>
#include<cstdio>
using namespace std;
int n,a[50][50],b[50],c[50];
int main()
{
    freopen("2615.in","r",stdin);
    freopen("2615.out","w",stdout);
    cin>>n;
    a[1][n/2+1]=1;
    b[1]=1;
    c[1]=n/2+1;
    for (int i=2;i<=n*n;i++)
    {
        if (b[i-1]==1 && c[i-1]!=n) 
        {
            b[i]=n;
            c[i]=c[i-1]+1;
        }
        if (c[i-1]==n && b[i-1]!=1)
        {
            b[i]=b[i-1]-1;
            c[i]=1;
        }
        if (b[i-1]==1 && c[i-1]==n)
        {
            b[i]=b[i-1]+1;
            c[i]=c[i-1];
        }
        if (c[i-1]!=n && b[i-1]!=1)
        {
            if (a[b[i-1]-1][c[i-1]+1]==0) {b[i]=b[i-1]-1;c[i]=c[i-1]+1;} else
            {b[i]=b[i-1]+1;c[i]=c[i-1];}
        }
        a[b[i]][c[i]]=i;
    }
    for (int i=1;i<=n;i++)
    {
    for (int j=1;j<=n;j++)
    printf("%d ",a[i][j]);
    printf("\n");
    }
    return 0;
}

回复

5 条回复,欢迎继续交流。

正在加载回复...