解题思路:
步骤如下:
先将不带空格的图形显示出来
分层次显示,先显示
XXXXX
XXX
再显示
X
XXX
XXXXX
再根据行的变化来显示前面的空,以及剔除中间的空
注意事项:(题目上面第一个演示中少去掉了一行)
参考代码:
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分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复