【java基础 4】树形结构数据呈现的非递归算法(循环)实现

2024-08-25 21:58

本文主要是介绍【java基础 4】树形结构数据呈现的非递归算法(循环)实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、基本概况

上一篇博客介绍到用递归实现树结构数据的查找,那么这篇博客,我就结合自己对于树的理解,然后用一种非递归的方式进行树结构数据的处理。首先,改造数据库表设计,加入度的概念:

 

首先,layer的设计,是来源于Word文档的目录带来的灵感。想一想我自己在写Word文档的时候,通过标题1,标题2等的设立,然后就可能自动生成目录。我感觉这个和我要完成的树结构数据的处理有共同之处。当然,在这里的010000,是我自己对于树的度的表示,主要是用于排序,而后面的depth,则是对于我自己方便在Java控制台打印额外添加的一个字段(实际应用,不需要)

 

然后是实体类设计:

 

<span style="font-family:KaiTi_GB2312;font-size:18px;">	private String id;private String name;private String pid;private String layer;private String depth;</span>


建立实体类的get和set方法

 

 

二、代码实现

1,查询所有的数据

 

<span style="font-family:KaiTi_GB2312;font-size:18px;">	public List<TreeEntity> findAllData() {<span style="color:#ff0000;">String sql = "select * from test where id is not null order by layer ASC";
</span>List<TreeEntity> treeList = null;try {conn = DbUtil.getConnection();pstmt = conn.prepareStatement(sql);rs = pstmt.executeQuery();treeList = new ArrayList<TreeEntity>();while (rs.next()) {TreeEntity myTree = new TreeEntity();myTree.setId(rs.getString("id"));myTree.setName(rs.getString("name"));myTree.setPid(rs.getString("pid"));myTree.setDepth(rs.getString("depth"));treeList.add(myTree);}} catch (SQLException e) {e.printStackTrace();} finally {DbUtil.close(pstmt);DbUtil.close(conn);}return treeList;}</span>


事实上,执行了这个方法之后,数据库的数据,就已经是按照菜单形式排列整齐的数据了。那么,怎么显示的更为美观呢?

 

2,显示树

 

<span style="font-family:KaiTi_GB2312;font-size:18px;">public void displayTree(){List<TreeEntity> List=this.findAllData();String prefix="";for(int i=0; i<List.size(); i++){if("1".equals(List.get(i).getDepth())){prefix="|-";}if("2".equals(List.get(i).getDepth())){prefix="|----";}if("3".equals(List.get(i).getDepth())){prefix="|--------";}System.out.println(prefix+List.get(i).getName());}}</span>

 

首先,这里有几个if语句,是我借助depth字段的值,来进行数据打印的一个过程。一般来说,作为一个系统的左侧边菜单,度的最大值,应该是在5个左右,少的话,直接在这里写。多的话,则有工厂方法模式可以简单改造。(而且,这一点只是我要在控制台打印出一棵树,自己额外加上的)

 

在实际应用中,比如说JQuery的ZTree插件,则有专门对应的简单Array形式的数据加载,如下:

第一种格式加载:标准的带有父子关系的ZTree加载

 

var zTreeNodes = [   {"id":1, "name":"test1", "nodes":[   {"id":11, "name":"test11", "nodes":[   {"id":111, "name":"test111"}   ]},   {"id":12, "name":"test12"}   ]},   ......   
];  


第二种格式加载:带有父子关系的简单Array格式加载

 

 

var treeNodes = [                                                                         {"id":1, "pId":0, "name":"test1"},   {"id":11, "pId":1, "name":"test11"},   {"id":12, "pId":1, "name":"test12"},   {"id":111, "pId":11, "name":"test111"},   ......   
];  


在实际应用的时候,完全可以采用第二种数据加载方式,让程序变得更为简单!

 

 

3,主程序代码及结果

 

<span style="font-family:KaiTi_GB2312;font-size:18px;">	public static void main(String[] args) {TreeDepth tree = new TreeDepth();tree.displayTree();}</span>

 

 

 

三、代码思考

可以看出的是,改造数据库设计之后,只用了1次循环,就实现了最终的效果,而没有用递归。那么问题的关键点有:每次插入数据的时候,layer的值填充问题,那么这个其实是有规律的,每个人都可能会有一套自己的填充规律,就比如说我的灵感则来自于Word文档的目录实现。

在用非递归实现了这个树的打印之后,我突然就明白了之前有一个姑娘问我的问题:她说为什么每次左侧边的菜单栏加载的时候,都要从上往下加载,而不是一次性加载完。今天跟了每一步代码之后发现,因为使用递归的时候,就是先把每一个结点的孩子结点全部遍历结束后,才会开始加载下一个结点。而使用非递归则不一样,因为它是一次性直接加载完所有的数据,所以是一次性加载完毕。

四、总结

对于平时的学习,还是多总结总结吧。我感觉,递归不递归的,其实也不那么重要,根据自己的实际情况进行取舍。

循环方法比递归方法快, 因为循环避免了一系列函数调用和返回中所涉及到的参数传递和返回值的额外开销。
 

递归和循环之间的选择。一般情况下, 当循环方法比较容易找到时, 你应该避免使用递归。
 

这篇关于【java基础 4】树形结构数据呈现的非递归算法(循环)实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1106764

相关文章

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Apache Ignite 与 Spring Boot 集成详细指南

《ApacheIgnite与SpringBoot集成详细指南》ApacheIgnite官方指南详解如何通过SpringBootStarter扩展实现自动配置,支持厚/轻客户端模式,简化Ign... 目录 一、背景:为什么需要这个集成? 二、两种集成方式(对应两种客户端模型) 三、方式一:自动配置 Thick

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

Spring WebClient从入门到精通

《SpringWebClient从入门到精通》本文详解SpringWebClient非阻塞响应式特性及优势,涵盖核心API、实战应用与性能优化,对比RestTemplate,为微服务通信提供高效解决... 目录一、WebClient 概述1.1 为什么选择 WebClient?1.2 WebClient 与

Java.lang.InterruptedException被中止异常的原因及解决方案

《Java.lang.InterruptedException被中止异常的原因及解决方案》Java.lang.InterruptedException是线程被中断时抛出的异常,用于协作停止执行,常见于... 目录报错问题报错原因解决方法Java.lang.InterruptedException 是 Jav

深入浅出SpringBoot WebSocket构建实时应用全面指南

《深入浅出SpringBootWebSocket构建实时应用全面指南》WebSocket是一种在单个TCP连接上进行全双工通信的协议,这篇文章主要为大家详细介绍了SpringBoot如何集成WebS... 目录前言为什么需要 WebSocketWebSocket 是什么Spring Boot 如何简化 We

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

Java Stream流之GroupBy的用法及应用场景

《JavaStream流之GroupBy的用法及应用场景》本教程将详细介绍如何在Java中使用Stream流的groupby方法,包括基本用法和一些常见的实际应用场景,感兴趣的朋友一起看看吧... 目录Java Stream流之GroupBy的用法1. 前言2. 基础概念什么是 GroupBy?Stream