打印螺旋方阵
【摘要】 #include <stdio.h> #define N 5#define max(a,b) ((a)<(b)?(b):(a))#define abs(a) ((a)>0?(a):(-a)) int foo(int x, int y){ int t = max(abs(x),abs(y)); int u = t + t; int v = u - ...
-
#include <stdio.h>
-
-
#define N 5
-
#define max(a,b) ((a)<(b)?(b):(a))
-
#define abs(a) ((a)>0?(a):(-a))
-
-
int foo(int x, int y)
-
{
-
int t = max(abs(x),abs(y));
-
int u = t + t;
-
int v = u - 1;
-
v = v * v + u;
-
-
if (x == -t)
-
{
-
v+= u + t - y;
-
}
-
else if (y == -t)
-
{
-
v += 3*u+x-t;
-
}
-
else if (y == t)
-
{
-
v += t - x;
-
}
-
else
-
{
-
v += y - t;
-
}
-
-
return v;
-
}
-
-
int main()
-
{
-
int x, y;
-
-
for (y=1-N; y<=N-1; y++)
-
{
-
for (x=1-N; x<=N-1; x++)
-
{
-
printf("%5d",foo(x,y));
-
}
-
printf("\n");
-
}
-
-
return 0;
-
}
-
文章来源: blog.csdn.net,作者:悦来客栈的老板,版权归原作者所有,如需转载,请联系作者。
原文链接:blog.csdn.net/qq523176585/article/details/11730527
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)