请大家帮忙看看这个程序。输出的程序是这样的: 1 2 3 4 12 13 14 5 11 16 15 6 10 9 8 7 5

intright(inta[20][20],int*i,int*j,int*n,int*fill){if(a[*i][*j]==(*n)*(*n))return1;for... int right(int a[20][20],int *i,int *j,int *n,int *fill)
{
if(a[*i][*j]==(*n)*(*n))
return 1;
for(*j;*j<*n;*j++)
{
if(a[*i][*j]==0)
{
a[*i][*j]=(*fill)++;
}
else
{
break;
}
}
*i++;
return 0;

}
int left(int a[20][20],int *i,int *j,int *n,int *fill)
{
if(a[*i][*j]==(*n)*(*n))
return 1;
for(*j;*j>=0;*j--)
{
if(a[*i][*j]==0)
a[*i][*j]=(*fill)++;
else
break;
}
*i--;
return 0;
}
int up(int a[20][20],int *i,int *j,int *n,int *fill)
{
if(a[*i][*j]==(*n)*(*n))
return 1;
for(*i;*i>=0;*i--)
{
if(a[*i][*j]==0)
a[*i][*j]=(*fill)++;
else
break;
}
*j++;
return 0;

}
int down(int a[20][20],int *i,int *j,int *n,int *fill)
{
if(a[*i][*j]==(*n)*(*n))
return 1;
for(*i;*i<*n;*i++)
{
if(a[*i][*j]==0)
a[*i][*j]=(*fill)++;
else
break;
}
*j--;
return 0;

}
int main()
{
static int a[20][20]={0},i=0,j=0,n,fill=0;
scanf("%d",&n);

while(1)
{
if((right(a,&i,&j,&n,&fill)||down(a,&i,&j,&n,&fill)||left(a,&i,&j,&n,&fill)||up(a,&i,&j,&n,&fill))==1)
{

break;

}

}
for(i=0;i<n;i++)
{
printf("\n");
for(j=0;j<n;j++)
{
printf("%5d",a[i][j]);
}
}
}
输出是这样的 螺旋形数组:

1 2 3 4
12 13 14 5
11 16 15 6
10 9 8 7
展开
 我来答
漃寞qwe捔落
2011-05-14
知道答主
回答量:4
采纳率:0%
帮助的人:0
展开全部
fggfgfgeryee5445454v4gdfgg.,.,m;,k.l./mjky554f5ft7yt8gd4g4r4ert4f544m,..,.,.,.,.,l;o;lkhjkj4,m5,4kllk lklk,.4l;kl;4k44,4.,.,5 ghgfhg 55555555555547
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
Sphinxzqa1
2011-05-14 · TA获得超过128个赞
知道答主
回答量:31
采纳率:0%
帮助的人:0
展开全部
⊙﹏⊙b汗
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
KM868
2011-05-15
知道答主
回答量:8
采纳率:0%
帮助的人:0
展开全部
天书啊
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2011-05-15
展开全部
BUZIDAO
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式