解题思路: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语言程序设计教程(第三版)课后习题7.3 (C语言代码)浏览:643 |
【绝对值排序】 (C++代码)浏览:720 |
大神老白 (C语言代码)浏览:690 |
字符串的输入输出处理 (C语言代码)浏览:1019 |
A+B for Input-Output Practice (IV) (C语言代码)浏览:484 |
1017题解浏览:663 |
C语言程序设计教程(第三版)课后习题8.1 (C语言代码)浏览:606 |
C语言程序设计教程(第三版)课后习题11.3 (C语言代码)浏览:2207 |
C语言程序设计教程(第三版)课后习题6.8 (C语言代码)浏览:683 |
小O的数字 (C++代码)浏览:806 |