望尽天涯路


私信TA

用户名:H1810819059

访问量:30275

签 名:

等  级
排  名 109
经  验 7849
参赛次数 6
文章发表 97
年  龄 0
在职情况 学生
学  校 贺州学院
专  业

  自我简介:

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

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换

万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区