您的位置:首页 > 其它

仙人球的残影

2016-07-22 16:46 337 查看
F - 仙人球的残影
Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u
Submit Status

Description

在美丽的HDU,有一名大三的同学,他的速度是众所周知的,跑100米仅仅用了2秒47,在他跑步过程中会留下残影的哎,大家很想知道他是谁了吧,他叫仙人球,既然名字这样了,于是他的思想是单一的,他总是喜欢从一点出发,经过3次转折(每次向右转90°),回到出发点,而且呢,他每次转折前总是跑相同长度的路程,所以很多人都想知道如果用‘1’算他跑步出发的第一个残影的话,那么回到起点的时候,他的残影是怎么样的呢?

Input

测试数据有多行,每一行为一个数N(1<=N<=10)(以0结尾,0不做处理),即仙人球在没有回到起点的时候,跑过留下N个残影后突然90°右转。

Output

每组测试数据输出一个结果,并且每个残影的计数位长度为3个字符长度。(当然N等于1的话,它的结果也是占用3个字符位置的)

Sample Input

4


Sample Output

1  2  3  4
12        5
11        6
10  9  8  7


/*第一行是n个数,第一行和最后一行是n-2个数,则左边数的规律是从4*n-4到3*n-3,右边是从n+1到2*n-2,然后再用一个循环

把这两组数输出,用数学计算找出这两组数和你的for循环之间的关系,把两组数输出去,中间用循环打印出空格

*/#include<stdio.h>//打印环形连续的数,先打印出开头结尾,中间的分开打印,然后在两组数中间打印n-2个空格,再换行就可以了

int main()

{

int i,j,k;

int n;

while(~scanf("%d",&n))

{

for(i=1;i<=n;i++)

{

printf("%3d",i);

}

printf("\n");

for(j=1;j<=n-2;j++)

{

printf("%3d",4*n-3-j);//不能用循环,这个可以用数学推导出来公式

for(i=1;i<=n-2;i++)

{

printf(" ");//注意,前边是%3d,所以这里应该是三个空格

}

printf("%3d",n+j);

printf("\n");

}

for(i=3*n-2;i>=2*n-1;i--)

{

printf("%3d",i);

}

printf("\n");

}

return 0;

}

//方法二用二维数组

#include<stdio.h>

#include<string.h>

#include<algorithm>

using namespace std;

int main()

{

int n,x,y,i,j,a[15][15];

while(scanf("%d",&n)&&n)

{

memset(a,0,sizeof(a));

int m=1;

x=y=1;

while(y<n)

a[x][y++]=m++;

while(x<n)

a[x++][y]=m++;

while(y>1)

a[x][y--]=m++;

while(x>1)

a[x--][y]=m++;

for(i=1;i<=n;i++)

{

for(j=1;j<=n;j++)

if(a[i][j])

printf("%3d",a[i][j]);

else

printf(" ");

printf("\n");

}

}

return 0;

}

//打印图形时,注意要处理好空格,基本上就没有大问题了
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: