仙人球的残影
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
Sample Output
/*第一行是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;
}
//打印图形时,注意要处理好空格,基本上就没有大问题了
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;
}
//打印图形时,注意要处理好空格,基本上就没有大问题了
相关文章推荐
- 判断3389端口是否开启
- (组合博弈)(sg函数模版)HDU 5724 Chess
- Java反编译
- 我的第一篇博客
- 分组 分页查询 (group by 和order by使用 )
- 通过ip连接android adb
- 2016年国内开源镜像站点汇总
- comments 在djiano 高版本问题
- Android继承Mob短信验证详解
- .Net语言 APP开发平台Smobiler3.2版本将于八月中旬发布!——3.2版本预告(一)
- golang使用sort接口实现排序示例
- 内存字节对齐
- 160722界面的颜色透明度渐变
- C++异常捕获和动态内存申请
- MFC类别型录网之对象动态创建
- 数字电视中相关概念1 :码率、符号率、带宽、宽带
- Ignatius and the Princess I
- Linux消息队列
- iOS开发之音轨合成(音频与音频,音频与视频)
- 录音简单使用