原题链接:DNA
解题思路:
1、这个题在做完了提交成功之后,去看题解。大致扫了一下别人的代码,长度都差不多。那可能就没有一个好的公式了只能暴力解题了。
2、第一步,求出一共要打印多少行,这个很简单,直接就是 a + (a-1) * (b-1)
3、然后就是去输出每一行数据。每一行又分三个部分。前置空格 中间空格 X
4、可以把这个图形看成一个对称的图形,我们每次只需要考虑一个对称的图形,其他的只需要和第一个一样。
5、至于 前置空格 和 中间空格 的规律就很好看出来了,这里就不说了可以去看看下面的代码
注意事项:
最后每次打印完的时候不要忘记了输出一个 换行
参考代码:
public static void main(String[] args) { Scanner in = new Scanner(System.in); int N = in.nextInt(); int k,front,flag,after,row; for (int i = 0;i < N; i++){ int a = in.nextInt(); int b = in.nextInt(); front = 0; flag = 1; row = a + (a-1)*(b-1); //一共有多少行 after = a - 2; //最多空个数 for (int j = 0; j < row; j++){ for (int m = 0;m < front; m++) //打印开头的空格 System.out.print(" "); System.out.print("X"); // 进入了这个判断,就说明,该上下倒置了 // flag > 0 说明是输出正金字塔 小于 0 就是输出负金字塔 if (front == a/2 || (front == 0 && j > 0)){ flag = -flag; if (flag < 0){ front--; after = 1; }else{ after = a - 2; front++; } //这句话就是判断,当前行,是否是 之需要打印一个 X,如果是就换行,然后 结束当层循环 if ( ((front+1) == a/2 && after == 1) || ( (front-1) == a/2 && after == a-2 ) ){ System.out.println(); continue; } } else { if (flag > 0) front++; else front--; } for (k = 0;k < after; k++) //打印中间的空格 System.out.print(" "); System.out.println("X"); if (flag > 0) after = after - 2; else after = after + 2; } // 当前一次结束后,换行 这是格式要求 System.out.println(); } }
0.0分
4 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复