Java输出镂空金字塔实现案例

根据用户输入,打印出相应层数的镂空金字塔 

1.第一步,打印出金字塔(非镂空)

import java.util.Scanner;
public class test{
	public static void main(String[] args) {
		System.out.println("请输入金字塔的层数");
		Scanner sc = new Scanner(System.in);
		int towerLevel = sc.nextInt();
		/*
			输入层数为5
				*			1层 1个*		1=1*2-1  空格数4
			   ***			2层 3个*		3=2*2-1	 空格数3
			  *****			3层	5个*		5=3*2-1	 空格数2
			 *******	 	4层	7个*		7=4*2-1  空格数1
			*********		5层 9个*   	    9=5*2-1  空格数0
			 				可以得出 *为  层数*2-1  空格数为总层数-本层数
		 */
		for(int i = 1; i <= towerLevel; i++){          //打印每一层,i代表当前层
			for(int k = 1; k <= towerLevel - i; k++){  //打印当前层的空格,空格数为总层数-本层数
				System.out.print(" ");
			}
			for(int j = 1; j <= i * 2 - 1; j++){       //打印当前层的*,j为当前要打印*在本行中的位置,每行的第一个位置是 j = 1, 最后一个位置是 j=i*2-1
					System.out.print("*");
			}
			System.out.println();
		}
	}
}

用户输入5以后,结果为:

2C03E86B-663C-B2B2-EBE5-81B0BC738698.png

2.分析如何打印出镂空金字塔

根据镂空金字塔的图形来看,如果当前层不在最底层,其余层都是只在本行的第一个位置和最后一个位置打印了*,其余位置都为空格,所以打印*的语句前可以加一个if判断条件:当前位置是当前层的第一个 或者 当前位置是当前层的最后一个 或者 当前层是最后一层,用代码体现就是if(j == 1 || j == 2 * i - 1 || i == towerLevel)。

import java.util.Scanner;
public class test{
	public static void main(String[] args) {
		System.out.println("请输入金字塔的层数");
		Scanner sc = new Scanner(System.in);
		int towerLevel = sc.nextInt();
		/*
			输入层数为5
				*			1层 1个*		1=1*2-1  空格数4
			   ***			2层 3个*		3=2*2-1	 空格数3
			  *****			3层	5个*		5=3*2-1	 空格数2
			 *******	 	4层	7个*		7=4*2-1  空格数1
			*********		5层 9个*   	    9=5*2-1  空格数0
			 				可以得出 *为  层数*2-1  空格数为总层数-本层数
		 */
		for(int i = 1; i <= towerLevel; i++){          //打印每一层,i代表当前层
			for(int k = 1; k <= towerLevel - i; k++){  //打印当前层的空格,空格数为总层数-本层数
				System.out.print(" ");
			}
			for(int j = 1; j <= i * 2 - 1; j++){       //打印当前层的*,j为当前要打印*在本行中的位置,每行的第一个位置是 j = 1, 最后一个位置是 j=i*2-1
				if(j == 1 || j == 2 * i - 1 || i == towerLevel){
					System.out.print("*");
				} else{
					System.out.print(" ");
				}
			}
			System.out.println();
		}
	}
}

用户输入5以后结果为:

E7375A37-30A6-DC8F-994B-2C36D5AD5BFA.png

这样就打印出了镂空金字塔。

收藏 (0)
评论列表
正在载入评论列表...
我是有底线的
为您推荐
    暂时没有数据