解题思路:

步骤如下:

  1. 先将不带空格的图形显示出来

  2. 分层次显示,先显示 

    XXXXX

      XXX

    再显示

        X

      XXX

    XXXXX

  3. 再根据行的变化来显示前面的空,以及剔除中间的空


注意事项:(题目上面第一个演示中少去掉了一行)
参考代码:

import java.util.Scanner;

public class DNA {

 /**
  * @param args
  */
 public static void main(String[] args) {
  // TODO Auto-generated method stub
  Scanner scanner = new Scanner(System.in);
  // 存储有几个数
  int frequency = scanner.nextInt();
  // 存储不同的DNA
  int[][] DNA = new int[frequency][2];
  for (int i = 0; i < frequency; i++) {
   for (int j = 0; j < 2; j++) {
    DNA[i][j] = scanner.nextInt();
   }
  }
  // 表示有连个dna要显示
  for (int i = 0; i < frequency; i++) {

   // 循环几遍
   for (int j = 0; j < DNA[i][1]; j++) {

    // 上部分
    if (j>0) {
     for (int j2 = 0; j2 < DNA[i][0]/2; j2++) {
      // 开始的空格
      for (int k = 0; k < j2; k++) {
       System.out.print(" ");
      }
      for (int k = 0; k <DNA[i][0]-2*j2; k++) {
       if (j2==0) {
        break;
       }
       if (k==0||k+1==DNA[i][0]-2*j2) {
        System.out.print("X");
       }else {
        System.out.print(" ");
       }
       
      }
      if (j2==0) {
       continue;
      }
       
      // 换行,准备输出第二个
      System.out.println();
      }
    }else {
     for (int j2 = 0; j2 < DNA[i][0]/2; j2++) {
      // 开始的空格
      for (int k = 0; k < j2; k++) {
       System.out.print(" ");
      }
      for (int k = 0; k <DNA[i][0]-2*j2; k++) {
       if (k==0||k+1==DNA[i][0]-2*j2) {
        System.out.print("X");
       }else {
        System.out.print(" ");
       }
       
      }
       
      // 换行,准备输出第二个
      System.out.println();
      }
    }
    
    //下班部分
    for (int j2 = 0; j2 <DNA[i][0]-DNA[i][0]/2; j2++) {
     for (int k = 0; k < DNA[i][0]/2-j2; k++) {
      System.out.print(" ");
     }
     for (int k = 0; k < 2*j2+1; k++) {
      if (k==0||k+1==2*j2+1) {
       System.out.print("X");
      }else {
       System.out.print(" ");
      }
      
     }
     System.out.println();
    }
    
    }
    
   // 换行,准备输出第二个
   System.out.println();
   }
   
  
  
  }
 
 

}


点赞(0)
 

0.0分

1 人评分

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

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

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

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

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

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

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

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

评论列表 共有 0 条评论

暂无评论