打印带字符的直角三角形
Print right angle triangle with characters
我想创建一个由字符组成的直角三角形。代码会问你想要三角形有多少行,当然最大是 26 行。当我测试代码时,我输入了 5(无缘无故)。到目前为止,这是我的代码:
import java.util.*;
public class Uppgift3 {
public static void main (String [] args) {
Scanner input = new Scanner (System.in);
System.out.print("Ange längden på de 2 lika långa sidorna (avsluta med -1): ");
int rader = input.nextInt();
int i = 0;
int j = 0;
int k = 0;
char bokstav = (char)( i + 'A');
for (i=0; i<rader; i++) {
for (j=0; j<i+1; j++) {
System.out.print(bokstav);
}bokstav++;
System.out.println();
}
}
}
这是我想要的输出(如果你输入 5):
A
AB
ABC
ABCD
ABCDE
这是我在上面的代码中输入 5 时得到的结果:
A
BB
CCC
DDDD
EEEEE
有人可以帮助我吗?我是在正确的轨道上,还是完全迷路了?感觉像后者……是的,这是给学校的。我已经尽力尝试了,现在卡住了。
非常感谢!
试试这个:
char bokstav = 'A';
for (i=0; i<rader; i++) {
bokstav = 'A';
for (j=0; j<i+1; j++) {
System.out.print(bokstav++);
}
System.out.println();
}
您没有在正确的位置递增 bokstav 变量。此外,您还需要每行重置它。
试试这个:
public static void main (String [] args)
{
Scanner input = new Scanner (System.in);
System.out.print("Enter the amount of rows your want: ");
int rows = input.nextInt();
char bokstav = 'A';
for(int i=0; i<rows; i++)
{
for(int j=0; j<i+1; j++)
{
System.out.print(bokstav);
bokstav++;
}
bokstav = 'A';
System.out.println();
}
}
你的解决方案的问题是你只在每行写入后增加字符;您应该在写入每个字符后递增字符。成功写入一行后,您应该将字符重置为 'A'.
for (int i = 0; i < 5; i++) {
char c = 'A';
for (int j = 0; j < i+1; j++) {
System.out.print(c);
c++;
}
System.out.println();
}
我还要指出这个解决方案不是recursion。递归方法的一个简单定义是调用自身以找到问题的较小部分的解决方案。例如,打印类似金字塔的递归解决方案看起来像这样。
public static void print(int level) {
if (level <= 0 || level > 26) {
return;
}
print(level - 1);
System.out.println(line(level));
}
public static String line(int level) {
String line = "";
if (level > 0 && level <= 26) {
line = line(level--) + (char)('A' + level);
}
return line;
}
我想创建一个由字符组成的直角三角形。代码会问你想要三角形有多少行,当然最大是 26 行。当我测试代码时,我输入了 5(无缘无故)。到目前为止,这是我的代码:
import java.util.*;
public class Uppgift3 {
public static void main (String [] args) {
Scanner input = new Scanner (System.in);
System.out.print("Ange längden på de 2 lika långa sidorna (avsluta med -1): ");
int rader = input.nextInt();
int i = 0;
int j = 0;
int k = 0;
char bokstav = (char)( i + 'A');
for (i=0; i<rader; i++) {
for (j=0; j<i+1; j++) {
System.out.print(bokstav);
}bokstav++;
System.out.println();
}
}
}
这是我想要的输出(如果你输入 5):
A
AB
ABC
ABCD
ABCDE
这是我在上面的代码中输入 5 时得到的结果:
A
BB
CCC
DDDD
EEEEE
有人可以帮助我吗?我是在正确的轨道上,还是完全迷路了?感觉像后者……是的,这是给学校的。我已经尽力尝试了,现在卡住了。
非常感谢!
试试这个:
char bokstav = 'A';
for (i=0; i<rader; i++) {
bokstav = 'A';
for (j=0; j<i+1; j++) {
System.out.print(bokstav++);
}
System.out.println();
}
您没有在正确的位置递增 bokstav 变量。此外,您还需要每行重置它。
试试这个:
public static void main (String [] args)
{
Scanner input = new Scanner (System.in);
System.out.print("Enter the amount of rows your want: ");
int rows = input.nextInt();
char bokstav = 'A';
for(int i=0; i<rows; i++)
{
for(int j=0; j<i+1; j++)
{
System.out.print(bokstav);
bokstav++;
}
bokstav = 'A';
System.out.println();
}
}
你的解决方案的问题是你只在每行写入后增加字符;您应该在写入每个字符后递增字符。成功写入一行后,您应该将字符重置为 'A'.
for (int i = 0; i < 5; i++) {
char c = 'A';
for (int j = 0; j < i+1; j++) {
System.out.print(c);
c++;
}
System.out.println();
}
我还要指出这个解决方案不是recursion。递归方法的一个简单定义是调用自身以找到问题的较小部分的解决方案。例如,打印类似金字塔的递归解决方案看起来像这样。
public static void print(int level) {
if (level <= 0 || level > 26) {
return;
}
print(level - 1);
System.out.println(line(level));
}
public static String line(int level) {
String line = "";
if (level > 0 && level <= 26) {
line = line(level--) + (char)('A' + level);
}
return line;
}