叠筐
2015-11-22 22:15
288 查看
[align=left]Problem Description[/align]
需要的时候,就把一个个大小差一圈的筐叠上去,使得从上往下看时,边筐花色交错。这个工作现在要让计算机来完成,得看你的了。
[align=left]Input[/align]
输入是一个个的三元组,分别是,外筐尺寸n(n为满足0<n<80的奇整数),中心花色字符,外筐花色字符,后二者都为ASCII可见字符;
[align=left]Output[/align]
输出叠在一起的筐图案,中心花色与外筐花色字符从内层起交错相叠,多筐相叠时,最外筐的角总是被打磨掉。叠筐与叠筐之间应有一行间隔。
[align=left]Sample Input[/align]
11 B A
5 @ W
[align=left]Sample Output[/align]
AAAAAAAAA
ABBBBBBBBBA
ABAAAAAAABA
ABABBBBBABA
ABABAAABABA
ABABABABABA
ABABAAABABA
ABABBBBBABA
ABAAAAAAABA
ABBBBBBBBBA
AAAAAAAAA
@@@
@WWW@
@W@W@
@WWW@
@@@
这个题目就是画圆圈的题目,但你要注意它的输出格式,换行,并且你要注意另外写出当它等于1是的情况,其实我的代码还可以简单一些就是在判断n+1是否能被4整除的时候你直接把a和b字母换一下就可以了。不用像我那样重复代码。
以下是我AC的代码,希望对大家有所帮助。
#include <stdio.h>
#include <stdlib.h>
int main()
{
int n,i,j,d=0,k;
char a,b,c[88][88];
while(scanf("%d %c %c",&n,&a,&b)!=EOF)
{
if(d==1)
printf("\n");
if(n==1)
{printf("%c\n",a);
d=1;
continue;}
if((n+1)%4==0)
{
for(j=0; j<n; j++)
{
for(i=j; i<n-j; i++)
{
if(j%2==0)
{
c[i][j]=b;
c[j][i]=b;
c[n-1-j][i]=b;
c[i][n-1-j]=b;
}
else
{
c[i][j]=a;
c[j][i]=a;
c[n-1-j][i]=a;
c[i][n-1-j]=a;
}
}
}
}
if((n+1)%4!=0)
{
for(j=0; j<n; j++)
{
for(i=j; i<n-j; i++)
{
if(j%2==0)
{
c[i][j]=a;
c[j][i]=a;
c[n-1-j][i]=a;
c[i][n-1-j]=a;
}
else
{
c[i][j]=b;
c[j][i]=b;
c[n-1-j][i]=b;
c[i][n-1-j]=b;
}
}
}
}
c[0][0]=' ';
c[n-1][n-1]=' ';
c[0][n-1]=' ';
c[n-1][0]=' ';
for(i=0; i<n; i++)
{
for(k=0; k<n; k++)
printf("%c",c[i][k]);
printf("\n");
}
d=1;
}
return 0;
}
需要的时候,就把一个个大小差一圈的筐叠上去,使得从上往下看时,边筐花色交错。这个工作现在要让计算机来完成,得看你的了。
[align=left]Input[/align]
输入是一个个的三元组,分别是,外筐尺寸n(n为满足0<n<80的奇整数),中心花色字符,外筐花色字符,后二者都为ASCII可见字符;
[align=left]Output[/align]
输出叠在一起的筐图案,中心花色与外筐花色字符从内层起交错相叠,多筐相叠时,最外筐的角总是被打磨掉。叠筐与叠筐之间应有一行间隔。
[align=left]Sample Input[/align]
11 B A
5 @ W
[align=left]Sample Output[/align]
AAAAAAAAA
ABBBBBBBBBA
ABAAAAAAABA
ABABBBBBABA
ABABAAABABA
ABABABABABA
ABABAAABABA
ABABBBBBABA
ABAAAAAAABA
ABBBBBBBBBA
AAAAAAAAA
@@@
@WWW@
@W@W@
@WWW@
@@@
这个题目就是画圆圈的题目,但你要注意它的输出格式,换行,并且你要注意另外写出当它等于1是的情况,其实我的代码还可以简单一些就是在判断n+1是否能被4整除的时候你直接把a和b字母换一下就可以了。不用像我那样重复代码。
以下是我AC的代码,希望对大家有所帮助。
#include <stdio.h>
#include <stdlib.h>
int main()
{
int n,i,j,d=0,k;
char a,b,c[88][88];
while(scanf("%d %c %c",&n,&a,&b)!=EOF)
{
if(d==1)
printf("\n");
if(n==1)
{printf("%c\n",a);
d=1;
continue;}
if((n+1)%4==0)
{
for(j=0; j<n; j++)
{
for(i=j; i<n-j; i++)
{
if(j%2==0)
{
c[i][j]=b;
c[j][i]=b;
c[n-1-j][i]=b;
c[i][n-1-j]=b;
}
else
{
c[i][j]=a;
c[j][i]=a;
c[n-1-j][i]=a;
c[i][n-1-j]=a;
}
}
}
}
if((n+1)%4!=0)
{
for(j=0; j<n; j++)
{
for(i=j; i<n-j; i++)
{
if(j%2==0)
{
c[i][j]=a;
c[j][i]=a;
c[n-1-j][i]=a;
c[i][n-1-j]=a;
}
else
{
c[i][j]=b;
c[j][i]=b;
c[n-1-j][i]=b;
c[i][n-1-j]=b;
}
}
}
}
c[0][0]=' ';
c[n-1][n-1]=' ';
c[0][n-1]=' ';
c[n-1][0]=' ';
for(i=0; i<n; i++)
{
for(k=0; k<n; k++)
printf("%c",c[i][k]);
printf("\n");
}
d=1;
}
return 0;
}
相关文章推荐
- ASP字符串转换函数用法
- linux下Oracle 10g安装(超级详细图解教程)
- 昌大大神养成计划之网页设计之路第五天
- Android读书笔记------Drawable
- Android高斯模糊、高斯平滑(Gaussian Blur)【2】
- maven POM.xml 标签详解
- MySQL日志——删除二进制日志
- yum_rpm(利用dvd建立本地yum库)
- 20135304刘世鹏——信息安全系统设计基础第十一周总结
- 最大限度利用 JavaScript 和 Ajax 性能
- 信息安全系统设计基础 实验二 固件设计 20135321余佳源 20135323符运锦
- 013--VS2013 C++ 地图贴图-其它格式图片
- php字符串处理函数大全
- linux 文件操作
- 数据库sql语句练习
- 第二百三十四天 how can I 坚持
- 第24篇 js小知识和坑
- Socket套接字/TCP
- SSH Spring无法注入的问题
- 组合键