Java语言程序设计基础篇_编程练习题**18.38 (递归树)

news2025/1/4 19:26:35

目录

题目:**18.38 (递归树)

代码示例

代码逻辑解释

类定义和变量初始化

main 方法

start 方法

drawRecursiveTree 方法

输出结果 


题目:**18.38 (递归树)

编写一个程序来显示一个递归树,如图18-20所示

  • 代码示例

编程练习题18_38RecursionTree.java

package chapter_18;

import javafx.application.Application;
import javafx.geometry.Pos;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.control.ContentDisplay;
import javafx.scene.control.Label;
import javafx.scene.control.TextField;
import javafx.scene.input.KeyCode;
import javafx.scene.layout.BorderPane;
import javafx.scene.paint.Color;
import javafx.scene.shape.Line;
import javafx.stage.Stage;

public class 编程练习题18_38RecursionTree extends Application{
	private int order;
	private int size;
	private int canvasWidth;
	private int canvasHeight;
	
	public static void main(String[] args) {
		Application.launch(args);
	}
	@Override
	public void start(Stage primaryStage) throws Exception {
		size = 300;
		canvasWidth = size;
		canvasHeight = size - 50;
		
		Group root = new Group();
		Scene scene = new Scene(root,size,size);
		
		TextField tfOrder = new TextField();
		Label lbOrder = new Label("Enter a umber",tfOrder);
		lbOrder.setContentDisplay(ContentDisplay.RIGHT);
		lbOrder.setAlignment(Pos.CENTER);
		
		BorderPane borderPane = new BorderPane();
		borderPane.setCenter(root);
		borderPane.setBottom(lbOrder);
		BorderPane.setAlignment(lbOrder, Pos.CENTER);
		
		tfOrder.setOnKeyPressed(e ->{
			if(e.getCode() == KeyCode.ENTER) {
				root.getChildren().clear();
				order = Integer.parseInt(tfOrder.getText());
				drawRecursiveTree(root,order,canvasWidth/8,canvasHeight/4,
						canvasHeight*0.24,Math.PI/2);
			}
		});
		scene.setRoot(borderPane);
		primaryStage.setTitle(getClass().getName());
		primaryStage.setScene(scene);
		primaryStage.show();
	}
	private void drawRecursiveTree(Group group,int order,double x,double y,double length,double angle) {
		if(order < 0)
			return;
		double x2 = x + length*Math.cos(angle);
		double y2 = y - length*Math.sin(angle);
		Line line = new Line(x,y,x2,y2);
		line.setStroke(Color.BLACK);
		group.getChildren().add(line);
		drawRecursiveTree(group, order-1, x2, y2, length*0.7, angle-Math.PI/6);
		drawRecursiveTree(group, order-1, x2, y2, length*0.7, angle+Math.PI/6);
	}
}
  • 代码逻辑解释

类定义和变量初始化
  • 类定义编程练习题18_38RecursionTree 类继承自 Application,是 JavaFX 应用程序的入口。
  • 变量初始化:类中定义了四个私有变量 order(树的阶数),size(窗口大小),canvasWidth(画布宽度),canvasHeight(画布高度)。注意,虽然 canvasWidth 和 canvasHeight 被初始化了,但在绘图过程中它们实际上并没有直接被用作限制条件,而是用于计算初始绘图的起始位置和长度。
main 方法
  • Application.launch(args);:这是 JavaFX 应用程序的标准启动方式,它接收命令行参数并启动应用程序。
start 方法
  • 初始化窗口大小size 设置为 300 像素,canvasWidth 和 size 相同,canvasHeight 设置为 size - 50,为底部留出空间放置控件。
  • 创建 Group 和 SceneGroup 对象 root 作为所有绘图元素的容器,Scene 对象 scene 设置了窗口的大小,并将 root 作为其内容。
  • 创建用户输入控件TextField 用于接收用户输入的阶数,Label 显示提示信息并与 TextField 关联。Label 的内容显示设置为右侧,文本对齐设置为居中(虽然这主要用于水平布局,但在这个垂直布局的 BorderPane 中可能看起来有些奇怪)。
  • 布局设置:使用 BorderPane 布局,将 root 设置为中心区域,Label(包含 TextField)设置为底部区域。TextField 在 BorderPane 中直接居中对齐的设置实际上是无效的,因为它被包含在 Label 中,而 Label 的对齐方式被设置为居中,但这主要影响的是文本的水平对齐。
  • 事件监听:为 TextField 设置按键事件监听器,当按下回车键时,清除 Group 中的所有子元素,解析用户输入的阶数,并调用 drawRecursiveTree 方法绘制树。
  • 设置并显示舞台:将 BorderPane 设置为场景的根节点,设置舞台的标题,将场景添加到舞台,并显示舞台。
drawRecursiveTree 方法
  • 递归逻辑:该方法通过递归调用自身来绘制树的每一级分支。
  • 参数:包括 Group 对象(用于添加线条)、阶数(order)、当前分支的起点坐标(xy)、分支的长度(length),以及当前分支的角度(angle)。
  • 递归终止条件:如果阶数小于 0,则递归结束。
  • 绘制线条:计算当前分支的终点坐标,创建 Line 对象,设置其颜色和起点终点坐标,并将其添加到 Group 中。
  • 递归调用:对当前分支的左右两侧进行递归调用,每次递归时减小分支长度并调整角度(左右分支分别减去和加上 Math.PI/6,即 30 度)。

  • 输出结果 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2160296.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python模块和包:自定义模块和包③

文章目录 一、模块1.1 什么是模块1.2 创建模块1.3 导入模块1.4 模块的命名空间 二、包2.1 什么是包2.2 创建包2.3 导入包2.4 包的命名空间 三、综合详细例子3.1 项目结构3.2 模块代码student.pycourse.pymanager.py 3.3 主程序代码main.py 3.4 运行结果 四、总结 Python模块和包…

regPractice-正则表达式练习

正则表达式练习(java) 1 . 校验密码强度 密码的强度必须是包含大小写字母和数字的组合&#xff0c;不能使用特殊字符&#xff0c;长度在8-10之间。 ^(?.*\d)(?.*\[a-z])(?.*[A-Z])[a-zA-Z\d]{8,10}$**(?pattern)**属于正向前瞻断言 正向前瞻断言的语法是 (?pattern)&a…

Android开发不用存储权限进行拍照

Android开发不用存储权限进行拍照 有时平台审核严&#xff0c;拍照时不能获取存储。这怎么办呢&#xff0c;拍照功能又不能去掉。 一、思路&#xff1a; 得自定义Camera&#xff0c;然后把拍照图片存在app目录下&#xff0c;再刷新到手机相册 二、效果图&#xff1a; Andro…

31省市农业地图大数据

1.北京市 谷类作物种植结构&#xff08;万亩&#xff09; 农作物种植结构&#xff08;万亩&#xff09; 2.天津市 谷类作物种植结构&#xff08;万亩&#xff09; 农作物种植结构&#xff08;万亩&#xff09; 3.黑龙江省 谷类作物种植结构&#xff08;万亩&#xff09; 农作物…

JVM 几种经典的垃圾收集器

目录 前言 Serial Serial Old ParNew Parallel Scavenge Parallel Old CMS收集器 garbage first 收集器 前言 回顾一下之前的几种垃圾收集算法: JVM java主流的追踪式垃圾收集器-CSDN博客文章浏览阅读646次&#xff0c;点赞22次&#xff0c;收藏16次。简要介绍了几…

【C++11新特性】多线程

目录 一、thread类 二、互斥锁 1.四种锁 &#xff08;1&#xff09;mutex &#xff08;2&#xff09;recursive_mutex &#xff08;3&#xff09;time_mutex &#xff08;4&#xff09;recurive_timed_mutex 2.lock_guard 3.unique_lock 4.锁的原理 三、原子操作 四…

供应链采购管理系统:开启智能采购新时代

在当今全球化的商业环境中&#xff0c;供应链管理的高效性和智能化对于企业的生存与发展至关重要。而供应链采购管理系统&#xff0c;尤其是智能采购系统&#xff0c;正成为企业提升竞争力的关键工具。 一、传统采购管理的挑战 传统的供应链采购管理往往面临着诸多难题。首先&a…

【计算机网络 - 基础问题】每日 3 题(二十二)

✍个人博客&#xff1a;Pandaconda-CSDN博客 &#x1f4e3;专栏地址&#xff1a;http://t.csdnimg.cn/fYaBd &#x1f4da;专栏简介&#xff1a;在这个专栏中&#xff0c;我将会分享 C 面试中常见的面试题给大家~ ❤️如果有收获的话&#xff0c;欢迎点赞&#x1f44d;收藏&…

【Python】多个dataframe存入excel的不同的sheet表里,而不会被覆盖的方法

我发现&#xff0c;我原来用的多个工作簿存入的方法&#xff0c;发现不太可行了。当使用for循环的时候&#xff0c;原来的sheet 会被新的表给覆盖&#xff0c;后来我找到一种新的方法&#xff1a; with pd.ExcelWriter(file_name ) as writer:Table.to_excel(writer, sheet_na…

程序打开了 但是不显示

程序打开了 但是不显示 失败起因尝试一尝试二 失败 起因 起因是我使用搜狗输入法发现图片表情后台显示打开了&#xff0c;但是在桌面上不显示 尝试一 选中程序&#xff0c;点击alt空格键 会出现还原页面选项 但是我的这个是灰色的 没用 尝试二 https://answers.microsof…

基于单片机的远程无线控制系统设计

摘 要 : 主要介绍了一种以单片机 AT89C2051 、 无线模块 APC200A-43 和继电器为核心的远程智能控制系统。 该系统通过对单片机功能的研究 , 使用单片机的输入输出口和中断实现对控制信号的处理, 通过调试无线通讯模块 , 控制接近开关实现对远程电机的启动 、 停止等控…

窗口函数性能提升50倍,PawSQL索引推荐实战案例

&#x1f31f;引言 在数据驱动的现代世界&#xff0c;SQL查询的速度是应用程序快速响应的关键。尤其是那些涉及窗口函数的复杂查询&#xff0c;若缺乏恰当的索引支持&#xff0c;性能瓶颈可能会成为阻碍。本文将带您看看PawSQL是如何通过智能索引推荐&#xff0c;帮助一个包含…

html+css学习

html 元素 html元素是HTML的根元素&#xff0c;一个文档只能有一个&#xff0c;其他所有元素都是其后代元素 html有一个属性为lang&#xff0c;其作用是&#xff1a; 帮助语言合成工具确定要使用的发音帮助翻译工具确定要使用的翻译规则 当属性lang“en”则表示告诉其浏览器…

数据结构与算法(Python)更新中

一、引入 先来看一道题: 如果 abc1000&#xff0c;且 a^2b^2c^2&#xff08;a,b,c 为自然数&#xff09;&#xff0c;如何求出所有a、b、c可能的组合? 枚举法&#xff1a; # 如果 abc1000&#xff0c;且 a^2b^2c^2&#xff08;a,b,c 为自然数&#xff09;&#xff0c;如何…

XSS闯关小游戏(前13关)

挖掘思路 1.存在可控参数 2.页面存在回显 3.使用带有特殊字符的语句去测试&#xff0c;网站是否进行了实例化 ( 例如 ">123 ) 4.构造闭合&#xff0c;实现payload的逃逸 1 name处参数可控&#xff0c;直接打即可 2 这里知道<>被实体编码了 再测试">1…

想转行AI大模型开发但不知如何下手?看这篇就够了!

原创 最近有很多小伙伴问我&#xff0c;之前从事的其他领域的编程&#xff0c;现在想要学习AI大模型开发的相关技能&#xff0c;不知道从哪下手&#xff0c;应该学习些什么&#xff0c;下面四个是我认为从事大模型开发&#xff0c;必须掌握的四个开源工具&#xff0c;大家可以…

14张图深度解密大厂秒杀系统库存设计,不是所有的库存都能支持高并发!

作者&#xff1a;冰河 星球&#xff1a;http://m6z.cn/6aeFbs 博客&#xff1a;https://binghe.gitcode.host 源码获取地址&#xff1a;https://t.zsxq.com/0dhvFs5oR 沉淀&#xff0c;成长&#xff0c;突破&#xff0c;帮助他人&#xff0c;成就自我。 大家好&#xff0c;我是…

应用在多钥匙应用程序-门锁、遥控器等领域的电容式触摸芯片-GT308L

触摸IC是一种集成了触摸感应技术的芯片&#xff0c;具有快速响应、高精准度和耐用性强的优点。可以实现高灵敏度的触控和准确的指令响应。在智能门锁的设计中&#xff0c;触摸IC不仅可以实现密码输入、指纹识别等功能&#xff0c;还可以与智能家居系统进行联动控制&#xff0c;…

【编程底层原理】Java常用读写锁的使用和原理

一、引言 在Java的并发世界中&#xff0c;合理地管理对共享资源的访问是至关重要的。读写锁&#xff08;ReadWriteLock&#xff09;正是一种能让多个线程同时读取共享资源&#xff0c;而写入资源时需要独占访问的同步工具。本文将带你了解读写锁的使用方法、原理以及它如何提高…

行人3d目标检测-车辆3d目标检测-3d目标检测(代码+教程)

在计算机视觉领域&#xff0c;准确地识别并定位物体对于多种应用来说至关重要&#xff0c;比如自动驾驶、机器人导航以及增强现实等。其中&#xff0c;三维边界框&#xff08;3D Bounding Box&#xff09;估计是一项关键技术&#xff0c;它允许系统不仅能够检测到图像中的物体位…