C语言:求高手帮我解释一下这个程序!!!这是一个求右螺旋的。

#include<stdio.h>voidmain(){inta[10][10]={0},i,j,row,col,dir_i,n;structdirectory{intx... #include <stdio.h>
void main()
{
int a[10][10]={0},i,j,row,col,dir_i,n;
struct directory
{
int x,y;
}dir[4]={{1,0},{0,1},{-1,0},{0,-1}};
printf("Enter n:");
scanf("%d",&n);
for(i=1,dir_i=0,row=col=0;i<=n*n;i++)
{
a[row][col]=i;
row+=dir[dir_i].x;
col+=dir[dir_i].y;
if(row<0||col<0||row>=n||col>=n||a[row][col]!=0)
{
row-=dir[dir_i].x;
col-=dir[dir_i].y;
dir_i++;
if(dir_i==4)
dir_i=0;
row+=dir[dir_i].x;
col+=dir[dir_i].y;
}
}
printf("Array a is :\n");
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
printf("%4d",a[i][j]);
printf("\n");
}
}
展开
 我来答
喻鹏程00
2012-03-12 · TA获得超过989个赞
知道小有建树答主
回答量:395
采纳率:0%
帮助的人:134万
展开全部
我终于看懂了,第一时间来讲给你听
如果你听懂了,给我加30分哦
螺旋首先加的是行,加完行再加列,然后减行,最后减列,如此循环
if里判断的是看行列有没有越界,当然越界还有另一种,即是a[row][col]!=0一开始没有赋值的元素自动给的0,现在不是0就是说已经到界限了
然后是if里面的执行问题了,因为我们判断的是越界,最后一个行和列已经越界,自减。再者就是dir_i自加一,就是进入下一个循环(就是我们自定义的数组),当然还要判断我们定义的数组有木有过界。在If里面最后一个行和列的加,我也不怎么会表达,就是本来的已经有值了,你加了之后上去赋值。
最后输出就是浮云了
2012sss2012
2012-03-17 · 超过24用户采纳过TA的回答
知道答主
回答量:74
采纳率:0%
帮助的人:72万
展开全部
#include <stdio.h>
void main()
{
int a[10][10]={0},i,j,row,col,dir_i,n;
struct directory
{
int x,y;
}dir[4]={{1,0},{0,1},{-1,0},{0,-1}};//这里定义结构体并声明dir
printf("Enter n:");
scanf("%d",&n);
for(i=1,dir_i=0,row=col=0;i<=n*n;i++)
{
a[row][col]=i;//========这里给点(row.col)赋值
row+=dir[dir_i].x;//=======对坐标点进行变换
col+=dir[dir_i].y;//=========沿着螺旋的方向递增
if(row<0||col<0||row>=n||col>=n||a[row][col]!=0)//======这里是判断该点是否

溢出
{
row-=dir[dir_i].x;//======对溢出的点进行变换
col-=dir[dir_i].y;//
dir_i++;//=============在这里变换点(row.col)的递变规则
if(dir_i==4)
dir_i=0;
row+=dir[dir_i].x;
col+=dir[dir_i].y;
}
}
printf("Array a is :\n");
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
printf("%4d",a[i][j]);
printf("\n");
}
}

这个程序沿着螺旋方向依次进行的,
(0,0)(0,1)(0,2)(0,3)
(1,0)(1,1)(1,2)(1,3)
(2,0)(2,1)(2,2)(2,3)
(3,0)(3,1)(3,2)(3,3)

从(0,0)(1,0)(2,0)(3,0)顺序变化,到达(3.0)时点已经溢出,所以进行if判断
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式