解题思路:1,先找出层数于行数,列数的对应关系:行==列==5+层数*4,定好字符数组范围!
2,然后把数组全部赋值'.'
3,在将十字图片分成两部分,中间部分和外围部分;
4,中间部分图片容易写,外围部分图片很难(切记这里要找对称性!!!!),具体看代码;
注意事项:这样数组下标从0开始!
参考代码:(复制到编译器上,查看更方便!)
#include<stdio.h>
#include<string.h>
#define N 1000
void dian(char a[][N],int s)
{
int i,j;
for(i=0;i<s;i++)
{
for(j=0;j<s;j++)
a[i][j]='.';
a[i][j]='\0';
}
}
void zhong(char a[][N],int s)
{
int i,j;
for(i=s/2-2;i<=s/2+2;i++)
{
a[s/2][i]='$';
a[i][s/2]='$';
}
}
int main()
{
char a[N][N];
int i,j,n,s,k,s1;
scanf("%d",&n);
s=5+n*4;
dian(a,s);
zhong(a,s);
for(i=1,j=0;i<=n;i++,j=j+2)
{
for(k=j+2;k<=s-j-3;k++)
{
a[j][k]='$';
a[s-1-j][k]='$';
a[k][j]='$';
a[k][s-1-j]='$';
}
k=j+2;
a[k][k-1]='$';
a[k][k]='$';
a[k-1][k]='$';
a[s-1-k][k-1]='$';
a[s-1-k][k]='$';
a[s-1-(k-1)][k]='$';
a[k][s-1-(k-1)]='$';
a[k][s-1-k]='$';
a[k-1][s-1-k]='$';
a[s-1-k][s-1-(k-1)]='$';
a[s-1-k][s-1-k]='$';
a[s-1-(k-1)][s-1-k]='$';
}
for(i=0;i<s;i++)
puts(a[i]);
return 0;
}
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复