解题思路:

注意事项:

参考代码:

#include <stdio.h>
#include <string.h>

int main(){
 int DNA[50][50];
 int n,a,b;
 int i,j;
 int l,r,t,flag;
 
 scanf("%d", &n);
 while(n){
  scanf("%d %d", &a,&b);
  memset(DNA,0,sizeof(DNA));
  flag = 0;
  l = 0;
  r = a-1;
  t = b;
  while(b){
   if(b == t){
    for(i = 0; i < a; i++){
     if(i == a/2){ //中间部分
      DNA[i][a/2] = 1;
      flag = 1;
     }
     else{ //上下两部分
      DNA[i][l] = 1;
      DNA[i][r] = 1;
     }
     if(flag == 0){
      l++;
      r--;
     }
     else{
      l--;
      r++;
     }
    } 
   }
   for(i = ((b==t)?(0):(1)); i <= a/2; i++){ //打印上部分以及中间部分
    for(j = 0; j < a-i; j++){
     if(DNA[i][j] == 1)
      printf("X");
     else
      printf(" ");
    }
    printf("\n");
   }
   for(i = a/2+1; i < a; i++){ //打印下部分
    for(j = 0; j < i+1; j++){
     if(DNA[i][j] == 1)
      printf("X");
     else
      printf(" ");
    }
    printf("\n");
   }
   b--;
  }
  printf("\n");
  n--;
 }
 
 return 0;
}

点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论