本文主要是介绍【模拟】神奇的幻方,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
样例输入#1
3
样例输出#1
8 1 6
3 5 7
4 9 2
思路
水题
模拟
#include<iostream>
#include<cstdio>
using namespace std;
int n,x,y,a[505][505];
int main()
{scanf("%d",&n);a[1][(n+1)/2]=1;x=1;y=(n+1)/2;for(int i=2;i<=n*n;i++){if(x==1 && y!=n)//判断{a[n][y+1]=i;x=n;y++;}else if(y==n && x!=1){a[x-1][1]=i;x=x-1;y=1;}else if(x==1 && y==n){a[x+1][y]=i;x=x+1;}else if(x!=1 && y!=n){if(!a[x-1][y+1]){a[x-1][y+1]=i;x--;y++;}else{a[x+1][y]=i;x=x+1;}}}for(int i=1;i<=n;i++){for(int j=1;j<=n;j++)printf("%d ",a[i][j]);printf("\n");}
}
这篇关于【模拟】神奇的幻方的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!