文章目录
- 问题描述
- 问题分析
- 1.确定框架
- 2.找到空格和星号的规律
- 3.打印空格数
- 4.打印星号数
- 5.完整代码
- 6.倒金字塔、直角三角形
问题描述
打印输出金字塔图案
输出效果像这样的:
*
***
*****
*******
*********
问题分析
这是一个很经典的for循环题,我们都知道,打印输出的时候,都是从最左端输出的,第一个星号是在中间的,而且星号之前有空格的,这里以点号来表示空格。
输出效果应该是这样的形式:
····*
···***
··*****
·*******
*********
1.确定框架
由上面我们可以看到,一共需要打印5行,而且每一行都是打印几个空格,然后再打印几个星号。这样我们就可以写出程序框架。代码如下:
public class Cym {
public static void main(String[] args){
*****************
for(i=1;i<=5;i++) //循环5次,打印5行
{
//打印若干个空格
//打印若干个星号
}
}
}
由于我们知道打印的行数,所以我们使用for循环来实现。下面我们就需要考虑怎样打印每行的星号。
2.找到空格和星号的规律
由上面的输出效果形式中可以发现:第1行的空格为4个,第2行是3个,第3行是2个,……,每行依次递减,直至最后一行空格数为0;而星号数目是第1行是1个,第2行是3,第3行是5,……,每行依次递增2,直至最后一行星号数为9。规律总结如下:
行数 | 空格数 | 空格数 | 星号数 | 星号数 |
1 | 4 | 5-1 | 1 | 1*2-1 |
2 | 3 | 5-2 | 3 | 2*2-1 |
3 | 2 | 5-3 | 5 | 3*2-1 |
4 | 1 | 5-4 | 7 | 4*2-1 |
5 | 0 | 5-5 | 9 | 5*2-1 |
规律 | 依次递减1 | 5-行数 | 依次递增2 | 行数*2-1 |
3.打印空格数
由于每行空格数有着“5-行数”的规律,在第i行的时候,空格数就为5-i,所以我们只要把5-i个空格打印出来。代码如下:
for(i=1;i<=5;i++)
{
for(j=1;j<=n-i;j++) //根据外层行号,输出星号左边空格
System.out.printf(" ");
}
虽然每行的空格数不同,但是对于特定的行,空格数是固定的,所以循环打印的次数是确定的,因此这里也用了for循环。
4.打印星号数
由于每行星号数有着“行数乘2-1”的规律,在第i行的时候,星号数就为"2乘i-1",所以我们只要把"2乘i-1"个星号打印出来。代码如下:
for(i=1;i<=5;i++)
{
for(k=1;k<=2*i-1;k++) //根据外层行号,输出星号个数
System.out.printf("*");
}
5.完整代码
把前面的程序进行组合,构成我们完整的代码。代码如下:
import java.util.Scanner;
public class Cym {
public static void main(String[] args){
int i,j,k,n;
Scanner input=new Scanner(System.in);
System.out.print("请输入金字塔层数:");
n=input.nextInt();
for(i=1;i<=n;i++){ //外层循环控制层数
for(j=1;j<=n-i;j++) //根据外层行号,输出星号左边空格
System.out.print(" ");
for(k=1;k<=2*i-1;k++) //根据外层行号,输出星号个数
System.out.print("*");
System.out.print("\n"); //一行结束,换行
}
}
}
6.倒金字塔、直角三角形
金字塔的兄弟姐妹——倒金字塔、直角三角形。
倒金字塔,代码如下:
import java.util.Scanner;
public class Cym {
public static void main(String[] args){
int i,j,k,n;
Scanner input=new Scanner(System.in);
System.out.print("请输入金字塔层数:");
n=input.nextInt();
for(i=1;i<=n;i++){
for(j=1;j<=i-1;j++)
System.out.print(" ");
for(k=1;k<=(n*2+1)-2*i;k++)
System.out.print("*");
System.out.print("\n");
}
}
}
直角三角形,代码如下:
import java.util.Scanner;
public class Cym {
public static void main(String[] args){
int i,j,k,n;
Scanner input=new Scanner(System.in);
System.out.print("请输入金字塔层数:");
n=input.nextInt();
for(i=1;i<=n;i++){
for(j=1;j<=n;j++)
System.out.print(" ");
for(k=1;k<=(n*2+1)-2*i;k++)
System.out.print("*");
System.out.print("\n");
}
}
}