相信大家在学习流程控制的循环结构时,一定都用for循环绘制过菱形和空心菱形吧,我记得我当时写的很麻烦,把一个菱形分为上下两部分,上面2重for循环,下面2重for循环,相信有很多的小伙伴都是这样做的吧,但是这样也造成了很多的代码冗余,今天无意间看到另外一种简便的方法,具体思路和实现过程如下图所示:
思路:
1.先画一个正方形,边长为奇数.
2.定义每一行的初始位置和结束位置,初始值为:边长/2+1.
3. 在每一行的输出位置和结束位置打印*,即为最中间的一条竖线.
4.改变初始位置和结束位置,上半部分菱形,初始位置--,结束位置++;下半部分相反.
5.在每一行的初始位置和结束位置之间打印*,即为实心菱形.
6.只在每一行的初始位置和结束位置处打印*,即为空心菱形.
第一步,输出正方形
public class PrintExample {
public static void main(String[] args) {
int size = 5;
for (int i = 1; i <= size; i++) {
for (int j = 1; j <= size; j++) {
System.out.print("*");
}
System.out.println();
}
}
}
结果:
第二步,输出一条竖线
public class PrintExample {
public static void main(String[] args) {
int size = 5;
int startPos = size/2 + 1;
int endPos = size/2 + 1;
for (int i = 1; i <= size; i++) {
for (int j = 1; j <= size; j++) {
if (j>=startPos && j<=endPos) {
System.out.print("*");
}else {
System.out.print(" ");
}
}
System.out.println();
}
}
}
效果:
第三步,输出实心菱形
public class PrintExample {
public static void main(String[] args) {
int size = 5;
int startPos = size/2 + 1;
int endPos = size/2 + 1;
boolean flag = true;
for (int i = 1; i <= size; i++) {
for (int j = 1; j <= size; j++) {
if (j>=startPos && j<=endPos) {
System.out.print("*");
}else {
System.out.print(" ");
}
}
if ((endPos - startPos + 1) == size) {
flag = false;
}
if (flag) {
startPos--;
endPos++;
}else {
startPos++;
endPos--;
}
System.out.println();
}
}
}
效果:
第四步,输出空心菱形
public class PrintExample {
public static void main(String[] args) {
int size = 5;
int startPos = size/2 + 1;
int endPos = size/2 + 1;
boolean flag = true;
for (int i = 1; i <= size; i++) {
for (int j = 1; j <= size; j++) {
if (j==startPos || j==endPos) {
System.out.print("*");
}else {
System.out.print(" ");
}
}
if ((endPos - startPos + 1) == size) {
flag = false;
}
if (flag) {
startPos--;
endPos++;
}else {
startPos++;
endPos--;
}
System.out.println();
}
}
}
效果:
总结:
编程要懂得转换思路,多思考,通常一个问题会有多种解决方法,我们要多思考,多尝试,找出最方便的方法.