原题链接: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、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复