原题链接:题目33 - ACM在线评测系统
时间限制:3000 ms | 内存限制:65535 KB
难度:3
描述
在n*n方阵里填入1,2,...,n*n,要求填成蛇形。例如n=4时方阵为:
10 11 12 1
9 16 13 2
8 15 14 3
7 6 5 4
输入
直接输入方阵的维数,即n的值。(n<=100)
输出
输出结果是蛇形方陈。
样例输入
3
样例输出
7 8 1
6 9 2
5 4 3
解题思路:
定义四组增量、一个状态方阵、一个蛇形方阵,蛇未经过,状态初始化为0;当蛇行路径上的当前值小于最后(最大)值时,从右上角作为起点开始加增量进行试探,若超出边界或蛇已经过,需要找下一组增量改变方向,否则方向不变;按原来增量或改变方向让蛇经过,并在状态方阵中,将经过的位置标记为1。
注意事项:
优秀代码展示了“螺旋”方阵的边界?
参考代码:
#include<stdio.h>
int main(){
int c,e,f,g,h,i,j,x,y,a[100][100];
//以下四组增量:同列行号加、同行列号减、同列行号减、同行列号加
int d[4][2]={{1,0},{0,-1},{-1,0},{0,1}};
int b[100][100]={0};//蛇未经过,初始化为0
scanf("%d",&c);
i=0;//起点行号
j=c-1;//起点列号
e=c*c;//蛇行路径上最后一个值
f=2;//蛇行路径上第二个值,同时也是当前值
g=0;//初始化开始访问第一组增量
h=c-1;//数组边界的行号或列号
b[i][j]=a[i][j]=1;//蛇的起点
while(f<=e){
x=i+d[g][0];//行加增量进行试探
y=j+d[g][1];//列加增量进行试探
if(x<0||x>h||y<0||y>h||b[x][y]){//超出边界或蛇已经过
if(++g==4) g=0;//判断过程中运行++g找下一组增量
i+=d[g][0];//改变方向
j+=d[g][1];//改变方向
}else{i=x;j=y;}//方向不变
b[i][j]=1;//蛇要经过的位置标记为1
a[i][j]=f++;//蛇已经过,当前值自加
}
for(e=0;e<c;e++){
for(f=0;f<h;f++)printf("%d ",a[e][f]);//e行中的前c-1个数
printf("%d\n",a[e][f]);//e行中的第c个数
}
return 0;
}优秀代码值得学习
/*
题目33优秀代码--运行号:99611
运行时间:2011-11-30 10:44:18 | 编程语言:C/C++ | 运行人:TC_张友谊
*/
#include<stdio.h>
int main()
{
int a,b,c,d,n,sum=1;
int yi[101][101];
scanf("%d",&n);
for(a=0;a<=(n-1)/2;a++)
{
for(b=a;b<=n-a-1;b++)
yi[b][n-a-1]=sum++;
for(b=n-2-a;b>=a;b--)
yi[n-a-1][b]=sum++;
for(b=n-a-2;b>=a;b--)
yi[b][a]=sum++;
for(b=a+1;b<n-a-1;b++)
yi[a][b]=sum++;
}
for(c=0;c<n;c++)
{
for(d=0;d<n;d++)
printf("%d ",yi[c][d]);
printf("\n");
}
}0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复