解题思路:
朝一个方向走,到边界就转,走过的标记过了就不走了。
注意事项:
注意输出格式
参考代码
#include<bits/stdc++.h> using namespace std; const int maxn = 103; int a[maxn][maxn]; int main() { int n,x,y,tot=0; while(scanf("%d",&n)==1) { memset(a,0,sizeof(a)); tot = a[x=0][y=n-1]=1; while(tot<n*n) { while(x+1<n&&!a[x+1][y]) a[++x][y] = ++tot; //向下 while(y-1>=0&&!a[x][y-1]) a[x][--y] = ++tot; //left while(x-1>=0&&!a[x-1][y]) a[--x][y] = ++tot; //up while(y+1<n&&!a[x][y+1]) a[x][++y] = ++tot; //right } for(x = 0; x<n;x++) { for(y=0;y<n;y++) if(y==n-1) printf("%d\n", a[x][y]); else printf("%d ", a[x][y]); } putchar('\n'); } return 0; }
0.0分
0 人评分
母牛的故事 (C语言代码)浏览:1301 |
C语言程序设计教程(第三版)课后习题12.1 (C语言代码)浏览:992 |
钟神赛车 (C++代码)浏览:869 |
【数组的距离】 (C语言代码)浏览:751 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:597 |
2006年春浙江省计算机等级考试二级C 编程题(2) (C语言代码)浏览:473 |
【求[X,Y]内被除3余1并且被除5余3的整数的和】 (C语言代码)浏览:679 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:634 |
1025题解浏览:744 |
Tom数 (C语言代码)浏览:496 |