java实现空心金字塔
前言
最近在学习java,遇到了一个经典打印题目,空心金字塔,初学者记录,根据网上教程,有一句话感觉很好,就是先把麻烦的问题转换成很多的简单问题,最后一一解决就可以了,然后先死后活,先把程序写死,后面在改成活的。
如下图是空心金字塔最终的实现效果,先要求用户输入层数然后输出

一.普通矩形
首先我们先把这个需求拆分,肯定是一堆星号里面扣出一个三角,那么我们先简单输出一个矩形,如下代码。
package test.test;
public class test {
public static void main(String[] args) {
//循环五次每次输出五个星号
for (int i = 1; i <=5 ; i++) {
System.out.println("*****");
}
}
}
输出效果图如下,非常简单。

二.普通三角形
既然输出了普通矩形,那么我们就可以来思考如何输出三角形,如下分析,是我们想要输出的效果,第一层是输出的一个,第二层是输出的两个,以此内推,思路是我们可以使用循环嵌套,第一层循环用来循环层数,第二层循环用来循环每层星号的个数。
* //第一层为一个
** //第二层位两个
*** //第三层位三个
****
*****
意思就是我们每层循环的个数小于等于层数即可,如下增加代码。
package test.test;
public class test {
public static void main(String[] args) {
//i为层数
for (int i = 1; i <=5 ; i++) {
//j为每层个数
for (int j = 1; j <= i ; j++) {
//print和println的区别就是print输出不会自带换行println会
System.out.print("*");
}
//每次循环完成一层那么就换行
System.out.print("\n");
}
}
}
如下图输出结果,可以输出三角形

三.输出等腰三角形
上面我们输出了普通三角形,我们现在需要输出等腰三角形,如下分析,也是我们需要输出的结果,首先可以发现,第一层为一个星号,第二层为三个星号,第三个为五个星号,是按按照奇数来的,但是也可以是2 * 层数 -1,所以每层的个数是2 * 层数 -1。
*
***
*****
*******
*********
如下代码修改,可以输出,修改的地方就是第二层循环j<=i变成了j<= 2 * i - 1,因为i代表的是层数。
package test.test;
public class test {
public static void main(String[] args) {
//i为层数
for (int i = 1; i <=5 ; i++) {
//j为每层个数
for (int j = 1; j <= 2 * i - 1 ; j++) {
//print和println的区别就是print输出不会自带换行println会
System.out.print("*");
}
//每次循环完成一层那么就换行
System.out.print("\n");
}
}
}
如下图输出效果,发现没有输出我们想要的效果。

我们需要进行修改,我们再来看一下最终效果,如下,发现前面是有空格的,空格的规律是啥啊?数一数可以发现,第一层的空格是四个,第二层的空格是3个,第三层的空格是2个……,仔细思考,发现就是总层数减去当前层数,比如第一层就是5-1,第二层就是5-2。
*
***
*****
*******
*********
思路是这样,代码的思路就是先在前面打印完成空格之后在打印星号,如下代码修改,修改的地方是在第二层循环的前面,加上了一个循环,是为了循环输出空格。
package test.test;
public class test {
public static void main(String[] args) {
//i为当前层数
for (int i = 1; i <=5 ; i++) {
//打印空格
for (int k = 1; k <= 5-i; k++) {
System.out.print(" ");
}
//j为每层个数
for (int j = 1; j <= 2 * i - 1 ; j++) {
//print和println的区别就是print输出不会自带换行println会
System.out.print("*");
}
//每次循环完成一层那么就换行
System.out.print("\n");
}
}
}
如下输出效果。

四.输出空心金字塔
前面已经输出了等腰三角形,现在需要把里面掏空,最终效果应该如下,分析一下怎么才能这样输出,首先不变的是第一层和最后一层,变化的是中间的层数,发现中间的都是输出了第一个和最后一个星号,最后一排就是输出全部
*
* *
* *
* *
*********
思路是,第一个星号即为判断,当j==1的时候那么就是输出第一个星号,当j == 2 * i - 1的时候即可输出最后一个星号,所以代码如下,更改的地方在循环每层循环的地方,加了一个判断,j==1的时候也就是输出每层第一个的时候,j == 2 * i -1的时候就是输出最后一个的时候。
package test.test;
public class test {
public static void main(String[] args) {
//i为当前层数
for (int i = 1; i <=5 ; i++) {
//打印空格
for (int k = 1; k <= 5-i; k++) {
System.out.print(" ");
}
//j为每层个数
for (int j = 1; j <= 2 * i - 1 ; j++) {
if (j == 1 || j == 2 * i - 1) {
//print和println的区别就是print输出不会自带换行println会
System.out.print("*");
} else {
System.out.print(" ");
}
}
//每次循环完成一层那么就换行
System.out.print("\n");
}
}
}
输出结果如下图,发现还是有一点问题。

问题出在判断的地方,最后一排应该是不用动的所以在判断的时候判断,如果i == 5的时候,那么还是一直输出,也就是当每层层数等于5的时候那么还是会输出星号。
如下修改代码。
package test.test;
public class test {
public static void main(String[] args) {
//i为当前层数
for (int i = 1; i <=5 ; i++) {
//打印空格
for (int k = 1; k <= 5-i; k++) {
System.out.print(" ");
}
//j为每层个数
for (int j = 1; j <= 2 * i - 1 ; j++) {
if (j == 1 || j == 2 * i - 1 || i == 5) {
//print和println的区别就是print输出不会自带换行println会
System.out.print("*");
} else {
System.out.print(" ");
}
}
//每次循环完成一层那么就换行
System.out.print("\n");
}
}
}
输出结果如下,发现成功输出空心金字塔。

五.实现先死后活
既然效果完成了,那么现在需要实现的是,可以自定义层数,让用户来输入层数,然后再来循环,很简单,思路就是使用scanner来接收,然后把下面每层的数字变成变量即可,代码如下。
package test.test;
import java.util.Scanner;
public class test {
public static void main(String[] args) {
//接收用户输入的值
Scanner input = new Scanner(System.in);
System.out.println("请输入层数字:");
int ceng = input.nextInt();
//i为当前层数
for (int i = 1; i <= ceng ; i++) {
//打印空格
for (int k = 1; k <= ceng-i; k++) {
System.out.print(" ");
}
//j为每层个数
for (int j = 1; j <= 2 * i - 1 ; j++) {
if (j == 1 || j == 2 * i - 1 || i == ceng) {
//print和println的区别就是print输出不会自带换行println会
System.out.print("*");
} else {
System.out.print(" ");
}
}
//每次循环完成一层那么就换行
System.out.print("\n");
}
}
}
输出效果如下图,会先叫我们输入数字来当作层数

因为我本人也是学习当中,如果有什么不对的地方,欢迎指正!(~ ̄▽ ̄)~
java实现空心金字塔的更多相关文章
- php练习——打印半金字塔、金字塔、空心金字塔、菱形、空心菱形
半金字塔 金字塔 空心金字塔 菱形 空心菱形
- java打印正金字塔,倒金字塔和“水影”金字塔
java打印正金字塔,倒金字塔和"水影"金字塔 --------原创文章,若要转载,请注明出处 小小少年 闲来无事,想起自己初学java的时候做的经典的无非就是打印出一些有意思 ...
- Java打印空心三角
Java打印空心三角 public static void main(String[] args) { int n=5; //n表示输出空心三角形行数,这里以5行为例 for(int i=1;i< ...
- Java打印空心菱形
使用Java打印空心菱形 public static void main(String[] args) { int n = 5; //这里输出菱形的上半部分 for (int i = 1; i < ...
- Javascript打印金字塔,倒立金字塔,空心金字塔,菱形,空心菱形等
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- java简单打印金字塔(案例)
学习编程语言,打印简单的金字塔是基础的案例,在这里就简单的写了个案例,希望能帮助到各位 代码 效果 class kinTa{ public static void main(String[] ...
- java代码实现 金字塔(倒置)
在jsp中实现如图所示的金字塔,,代码如下: 大致思路如下: 1.先画出前5行.因为 i+空格数=总行数,所以第一行的空格数是 总行数-i(第几行),然后画出 *,*的数目=2*i-11: 2.在画出 ...
- java输出空心菱形
package com.zsh; import java.util.Scanner; public class Test08 { public static void main(String[] ar ...
- Java温故而知新-空心菱形
空心菱形 今天做题练手,题目是空心菱形,一开始没什么思路,去网上找了找,发现很难找到讲的通透的,自己现在独立做出来了,记录一下,以备后用. * * * * * * * * * * * * * * * ...
随机推荐
- 动态JDK代理方式-实现类增强
需求描述: 抽取dao层开启和提交事物交由代理类一并执行 分析: 假如UserDao接口中有很多方法,例如addUser().deleteUser().updateUser()等等,需要频繁的和数据库 ...
- Homebrew 卸载后重新安装mysql
1.卸载https://blog.csdn.net/liuxw1/article/details/81434005 https://jingyan.baidu.com/article/5553fa82 ...
- Servlet与JSP之间相互传值问题
一.JSP向Servlet传值 JSP向Servlet传值的方式有三种:URL后面跟参数.form表单提交.在JSP内置对象Session设置值. URL后面跟参数 JSP文件:<a href= ...
- JVM监控工具介绍jstack, jconsole, jinfo, jmap, jdb, jsta
JVM监控工具介绍 jstack - 如果java程序崩溃生成core文件,jstack工具可以用来获得core文件的java stack和native stack的信息,从而可以轻松地知道java程 ...
- TOP 10 开源的推荐系统简介
最 近这两年推荐系统特别火,本文搜集整理了一些比较好的开源推荐系统,即有轻量级的适用于做研究的SVDFeature.LibMF.LibFM等,也有重 量级的适用于工业系统的 Mahout.Oryx ...
- MTK平台电路设计01
一.资料 获取途径MTK官网.一牛网 二.
- 解决Mui中popover 顶部弹出菜单弹出位置不准确以及无法收回的问题
前言 最近公司的项目转向使用Hbuilder开发移动端项目,其中想要通过在顶部标题栏加入弹出菜单的方式,来定位长列表的位置,如图所示. 问题 Mui的功能貌似还不是很完善,在使用这个弹出菜单的时候,发 ...
- 关于allegro找不到env文件解决方法
使用allegro的友人时对于env文件并不陌生.在我们设计的过程中经常使用env文件设置快捷键从而达到快速拉线的目的.但是新安装的allegro软件中会找不到env文件,因为今天自己碰到了这件事,并 ...
- [ Shell ] 通过 Shell 脚本导出 CDL 网表
https://www.cnblogs.com/yeungchie/ 通过 si 导出电路网表,实际上在 Virtuoso 中通过 export - cdl 和 Calibre LVS 的步骤中也是通 ...
- JS正则表达式学习记录
JS:正则表达式学习记录 <!DOCTYPE html> <html lang="en"> <head> <meta charset=&q ...