Java金字塔、空心金字塔、空心菱形

Java金字塔

java 复制代码
public class TestDemo01 {
    public static void main(String[] args){
        //第一个for用于每行输出 从i=1开始到i<=5,总共5行
        for(int i=1;i<=5;i++){

            //每行前缀空格,这个for用于表示每行输出*前面的空格
            //从上面规律可得,每行输出的空格数为总层数,可以用5-i表示
            for(int k=1;k<=5-i;k++){
                System.out.print(" ");
            }
            //每行*号,可以发现每行输出的*为当前层*2-1,所以用2*i-1表示
            for(int j=1;j<=2*i-1;j++){
                System.out.print("*");
            }
            System.out.println();
        }

    }
}

空心金字塔

java 复制代码
public class TestDemo01 {
    public static void main(String[] args){
       //行数
        for(int i=1;i<=5;i++){

            //每行前缀空格
            for(int k=1;k<=5-i;k++){
                System.out.print(" ");
            }
            //每行*号
            for(int j=1;j<=2*i-1;j++){
                //使用if做判断j==1时是首输出*,j==2*i-1为尾,i==5表示最后一行
                    if(j==1||j==2*i-1||i==5){
                        System.out.print("*");
                    }else{
                        System.out.print(" ");
                    }
            }

            System.out.println();
        }
}

空心菱形

相信有了以上基础后,写一个空心菱形不难,本质上就是将正空心金字塔倒过来,然后2个金字塔拼接起来,具体代码如下

java 复制代码
public class TestDemo01 {
    public static void main(String[] args){
       //行数
        for(int i=1;i<=5;i++){

            //每行前缀空格
            for(int k=1;k<=5-i;k++){
                System.out.print(" ");
            }
            //每行*号
            for(int j=1;j<=2*i-1;j++){
                    if(j==1||j==2*i-1){
                        System.out.print("*");
                    }else{
                        System.out.print(" ");
                    }
            }

            System.out.println();
        }

       for(int i = 1,j=5;i<=5;i++,j--){

            for (int k=1;k<i;k++){
                System.out.print(" ");
            }

            for(int z=1;z<=2*j-1;z++){
                if(z==1||z==(2*j-1)){
                    System.out.print("*");
                }else{
                    System.out.print(" ");
                }

            }
            System.out.println();
        }

    }
}
相关推荐
☆璇37 分钟前
【数据结构】排序
c语言·开发语言·数据结构·算法·排序算法
我要成为c嘎嘎大王37 分钟前
【C++】初识C++(1)
开发语言·c++
良木林41 分钟前
JavaScript书写基础和基本数据类型
开发语言·前端·javascript
梁同学与Android2 小时前
Android ---【内存优化】常见的内存泄露以及解决方案
android·java·内存泄漏
武子康3 小时前
Java-71 深入浅出 RPC Dubbo 上手 父工程配置编写 附详细POM与代码
java·分布式·程序人生·spring·微服务·rpc·dubbo
艾莉丝努力练剑4 小时前
【LeetCode&数据结构】单链表的应用——反转链表问题、链表的中间节点问题详解
c语言·开发语言·数据结构·学习·算法·leetcode·链表
武子康5 小时前
Java-72 深入浅出 RPC Dubbo 上手 生产者模块详解
java·spring boot·分布式·后端·rpc·dubbo·nio
_殊途5 小时前
《Java HashMap底层原理全解析(源码+性能+面试)》
java·数据结构·算法
椰椰椰耶6 小时前
【Spring】拦截器详解
java·后端·spring
没有bug.的程序员7 小时前
JAVA面试宝典 - 《MyBatis 进阶:插件开发与二级缓存》
java·面试·mybatis