原题链接:题目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");
	}
}


点赞(1)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论