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

算法描述

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

算法逻辑分析

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

Java算法代码

算法主函数:

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

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

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

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

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

生成矩阵数据的函数:

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

相关推荐
Dr.F.Arthur31 分钟前
我的算法笔记——哈希表篇
数据结构·笔记·散列表
小肝一下32 分钟前
每日两道力扣,day2
c++·算法·leetcode·职场和发展
漂流瓶jz42 分钟前
UVA-11846 找座位 题解答案代码 算法竞赛入门经典第二版
数据结构·算法·排序算法·深度优先·aoapc·算法竞赛入门经典·uva
米粒11 小时前
力扣算法刷题 Day 31 (贪心总结)
算法·leetcode·职场和发展
少许极端1 小时前
算法奇妙屋(四十)-贪心算法学习之路7
java·学习·算法·贪心算法
AlenTech2 小时前
647. 回文子串 - 力扣(LeetCode)
算法·leetcode·职场和发展
py有趣2 小时前
力扣热门100题之合并两个有序链表
算法·leetcode·链表
8Qi82 小时前
LeetCode热题100--45.跳跃游戏 II
java·算法·leetcode·贪心算法·编程
foundbug9993 小时前
基于STM32的步进电机加减速程序设计(梯形加减速算法)
stm32·单片机·算法
东北甜妹3 小时前
MYSQL 总结
数据结构