算法开发指导-数据结构-Tree

算法描述

给定由n个节点组成的树以及节点间的边对应的权,树上两节点间的距离定义为两节点间简单路径上所有边权的异或和,计算树上任意两节点路径的最大距离,以及给定一个正整数k,计算树上节点路径距离大于k的节点路径总数。

算法逻辑分析

|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 使用矩阵的数据结构存储一颗树形结构,矩阵中节点之间有边的元素值为1,无边的元素值为0。 定义二维数组存储树形结构的节点之间的权值,第一维数组的索引值表示树形结构的序号,第二维数组索引值表示树形结构的序号,第二维数组的元素值表示节点之间的权值,n个节点的树形结构,矩阵大小为n*n,二维数组大小为n*n。 遍历树形结构对应的矩阵关系的二维数组,计算所有节点路径的距离,得出节点路径距离的最大值。 遍历树形结构对应的矩阵关系的二维数组,计算所有节点路径的距离,得出节点路径距离大于k的节点路径总数。 |

Java算法代码

算法主函数:

显示节点路径信息的函数:

按照范围查询节点路径距离的函数:

查询节点路径最大距离的函数:

计算矩阵节点路径距离的函数:

计算节点路径距离的函数:

生成矩阵数据的函数:

生成树形结构数据的函数:

相关推荐
YL200404264 小时前
048路径总和III
数据结构·dfs
z200509304 小时前
每日简单算法题——————跟着卡尔
算法
️是785 小时前
信息奥赛一本通—编程启蒙(3395:练68.3 车牌问题)
数据结构·c++·算法
Liangwei Lin5 小时前
LeetCode 118. 杨辉三角
算法·leetcode·职场和发展
计算机安禾5 小时前
【c++面向对象编程】第24篇:类型转换运算符:自定义隐式转换与explicit
java·c++·算法
鼠鼠我(‘-ωก̀ )好困5 小时前
leetGPU
算法
我星期八休息6 小时前
Linux系统编程—基础IO
linux·运维·服务器·c语言·c++·人工智能·算法
池塘的蜗牛6 小时前
A Low-Complexity Method for FFT-based OFDM Sensing
算法
故事和你916 小时前
洛谷-【图论2-1】树5
开发语言·数据结构·c++·算法·动态规划·图论
咖啡里的茶i7 小时前
视觉显著目标的自适应分割与动态网格生成算法研究
人工智能·算法·目标跟踪