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

算法描述

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

算法逻辑分析

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

Java算法代码

算法主函数:

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

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

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

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

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

生成矩阵数据的函数:

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

相关推荐
aini_lovee6 分钟前
MATLAB圆锥滚子轴承滚子参数分析程序
人工智能·算法·matlab
_olone10 分钟前
牛客每日一题:显生之宙(Java)
java·开发语言·算法·牛客
嫂子开门我是_我哥25 分钟前
心电域泛化研究从0入门系列 | 第二篇:心电信号预处理全攻略——扫清域泛化建模的第一道障碍
人工智能·算法·ecg
wefg11 小时前
【算法】算数基本定理、分解质因数
算法
j_xxx404_1 小时前
力扣困难算法精解:串联所有单词的子串与最小覆盖子串
java·开发语言·c++·算法·leetcode·哈希算法
挠头猴子1 小时前
一个数组去重,两个数组找不同或相同
数据结构·算法
big_rabbit05021 小时前
[算法][力扣167]Two Sum II
算法·leetcode·职场和发展
颜酱1 小时前
二分图核心原理与判定算法
javascript·后端·算法
筱砚.2 小时前
C++——lambda
开发语言·c++·算法
Eward-an2 小时前
LeetCode 76. 最小覆盖子串(详细技术解析)
python·算法·leetcode·职场和发展