如何制作线条为1、3、5、3、5、7、5、7、9、7、9 ...的圣诞树?
圣诞树应如下所示:
x
xxx
xxxxx
xxx
xxxxx
xxxxxxx
xxxxx
xxxxxxx
xxxxxxxxx
xxxxxxx
xxxxxxxxx
xxxxxxxxxxx
它要求用户输入行数。到目前为止,我已经知道了。较早地制作了吡喃酰胺*
import java.util.Scanner;
public class Pyramide {
public static void main(String[] args) {
// les inn antall rader
System.out.println("Hvor mange rader skal pyramiden ha?");
int antallRader;
Scanner tastatur = new Scanner(System.in);
antallRader = tastatur.nextInt();
// skrive ut en kolonne som har saa mange rader som det ble angitt
// for hver verdi som rad kan faa naar rad starter paa 1, er mindre
// eller lik antallRader, og oekes hver gang med 1)
// for hver verdi mellom startverdien og sluttverdien med avstand 1
// gjenta
for (int rad = 1; rad <= antallRader; rad++) {
for (int antallTomt = 1; antallTomt <= antallRader - rad; antallTomt++) {
System.out.print(" ");
}
for (int antallX = 1; antallX <= 2 * rad - 1; antallX++) {
System.out.print("x");
}
for (int antallX = 1; antallX <= 2 * rad - 1; antallX++) {
System.out.print("x");
}
System.out.println();
}
}
}
我发现其循环以某种方式变为+ 2,+ 2,-2。但是我不知道如何编程。
最佳答案
你真亲密请考虑:
int linjer = 0;
int radDenneGang = 1;
while (linjer < antallRader) {
int antallRaderDenneGang;
if (antallRader - linjer >= 3)
antallRaderDenneGang = radDenneGang + 2;
else
antallRaderDenneGang = radDenneGang + antallRader - linjer - 1;
for (int rad = radDenneGang; rad <= antallRaderDenneGang; rad++) {
for (int antallTomt = 1; antallTomt <= antallRader - rad; antallTomt++) {
System.out.print(" ");
}
for (int antallX = 1; antallX <= 2 * rad - 1; antallX++) {
System.out.print("x");
}
// for (int antallX = 1; antallX <= 2 * rad - 1; antallX++) {
// System.out.print("x");
// }
System.out.println();
}
linjer += antallRaderDenneGang - radDenneGang + 1;
radDenneGang++;
}
使用
antallRader=15
,它会产生以下美丽的圣诞树: x
xxx
xxxxx
xxx
xxxxx
xxxxxxx
xxxxx
xxxxxxx
xxxxxxxxx
xxxxxxx
xxxxxxxxx
xxxxxxxxxxx
xxxxxxxxx
xxxxxxxxxxx
xxxxxxxxxxxxx