用java解决空心金字塔的问题

(一).空心金字塔对于初学编程是有一定的挑战的,对于这样复杂的问题需要借助化繁为简的操作。

涉及到循环的多级嵌套。

1.观察这个金子塔的外形,可以通过矩阵,然后矩阵去掉一半,形成歪的金子塔,然后将这个歪的金字塔 扶正将中间镂空.

2.写代码的过程,矩阵通过两层for循环,注意层数和输入进来的toterLevel有关系,而星星的数量是层数的两倍减1,构建一个起来了一个框架,在歪三角金字塔中观察第一层有一个星星,第二层有三个,第三层有5个第四层有7个,第五层有9个,和层数呈二倍减一的现象。然后将歪三角扶正,第一层有四个空格,第二层有三个以此递减,和层数呈现出totel-i这个特性,然后将金字塔内部掏空,只留下第一个和最后一个,上面说过星星是被空格挤压到相应的位置的,这个时候只需要留下j=1和j=2*i-1,注意这里,这个地方有点绕。最后再加上一个判断,当是第五层的时候保留所有的星星。

复制代码
import java.util.Scanner;
public class Test{
	public static void main(String[] args){
		Scanner myScanner=new Scanner(System.in);
		System.out.println("请输入一个塔的层数");
	    int toterlevel=myScanner.nextInt();
	    int i=1;
	    int j=1;
	    for(i=1;i<=toterlevel;i++){//控制层数
	    	for(int k=1;k<=toterlevel-i;k++){//将歪金字塔扶正
	    		System.out.print(" ");
	    	}
	    	for(j=1;j<=2*i-1;j++){//实心金字塔

	    		if(j==1||j==2*i-1||i==toterlevel){//空心金字塔
	    		System.out.print("*");
	    		}
	    		else{
	    			System.out.print(" ");
	    		}
	    	}
	    	System.out.print("\n");//换行
	    }
	    }
}
相关推荐
寻见9031 小时前
告别只会 CRUD!Spring 核心原理吃透,这一篇就够了(Java 程序员必藏)
java·后端·spring
Moe4881 小时前
基于 AOP 与 Redisson 的分布式锁实现:自动加锁、解锁与 SpEL 参数解析
java·后端·架构
敲代码的嘎仔1 小时前
Java后端开发——Redis面试题汇总
java·开发语言·redis·学习·缓存·面试·职场和发展
啦啦啦_99991 小时前
4. AI面试题之 Prompt
java·prompt
YmaxU1 小时前
SpringAIAlibaba学习使用 ---核心API、RAG、Tool Calling
java·学习·spring·ai
天若有情6731 小时前
【原创发布】typechecker:一款轻量级 JS 模板化类型检查工具
开发语言·javascript·npm·ecmascript·类型检查·typechecker
实心儿儿1 小时前
C++ —— 继承
开发语言·c++
佛系豪豪吖2 小时前
OpenClaw(龙虾)彻底卸载教程|Windows+Mac通用,3步无残留
开发语言
乘风破浪的小太阳2 小时前
Python之Playwright+AI UI自动化测试框架搭建与实战
人工智能·python·ui