解题思路: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 人评分

  评论区

  • «
  • »