解题思路: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二级辅导-计负均正 (C语言代码)浏览:598 |
大神老白 (C语言代码)浏览:715 |
【明明的随机数】 (C++代码)浏览:781 |
拆分位数 (C语言代码)浏览:1328 |
C语言程序设计教程(第三版)课后习题6.10 (C语言代码)浏览:561 |
C语言训练-列出最简真分数序列* (C语言代码)浏览:619 |
三角形 (C++代码)记忆化搜索浏览:1234 |
WU-C语言程序设计教程(第三版)课后习题11.12 (C++代码)(想学链表的小伙伴可以看看)浏览:904 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:678 |
数组与指针的问题浏览:718 |