当前位置:网站首页>如何将二叉搜索树转化为一个有序的双向链表(原树上修改)
如何将二叉搜索树转化为一个有序的双向链表(原树上修改)
2022-08-04 21:10:00 【陈亦康】

注意事项:
1.要求不能创建任何新的结点,只能调整树中结点指针的指向。当转化完成以后,树中节点的左指针需要指向前驱,树中节点的右指针需要指向后继
2.返回链表中的第一个节点的指针
3.函数返回的TreeNode,有左右指针,其实可以看成一个双向链表的数据结构
4.你不用输出双向链表,程序会根据你的返回值自动打印输出分析:




代码如下:
import java.util.*;
public class Solution {
TreeNode prev = null;
public TreeNode createList(TreeNode root){
if(root == null){
return null;
}
createList(root.left);
root.left = prev;
if(prev != null){
prev.right = root;
}
prev = root;
createList(root.right);
return root;//最后返回根结点
}
public TreeNode Convert(TreeNode pRootOfTree) {
if(pRootOfTree == null){
return null;
}
TreeNode head = createList(pRootOfTree);
//需要遍历到链表的头节点
while(head.left != null){
head = head.left;
}
return head;
}
}
边栏推荐
猜你喜欢

Comic | Two weeks after the boss laid me off, he hired me back and doubled my salary!

【PCBA program design】Grip dynamometer program

无代码平台字段设置:基础设置入门教程

STP --- 生成树协议
![[Data Mining] Written Exam Questions for Sohu Data Mining Engineers](/img/d9/450eeecd5c7835d40ac38da41fc08e.png)
[Data Mining] Written Exam Questions for Sohu Data Mining Engineers

DGL安装教程

宝塔实测-搭建中小型民宿酒店管理源码

After the tester with 10 years of service "naked resignation" from the big factory...

大势所趋之下的nft拍卖,未来艺术品的新赋能

【2022杭电多校5 1012题 Buy Figurines】STL的运用
随机推荐
数据仓库(1)什么是数据仓库,数仓有什么特点
2022年江苏省大学生电子设计竞赛(TI杯)B题 飞机 省级一等奖记录 “一个摆烂人的独白”
PCBA scheme design - kitchen voice scale chip scheme
visual studio 2015 warning MSB3246
88. (the home of cesium) cesium polymerization figure
MATLAB中readtimetable函数用法
简述@RequestParam与@RequestBody参数注解
LayaBox---knowledge point
数电快速入门(三)(卡诺图化简法的介绍)
LayaBox---TypeScript---结构
项目难管理?先学会用好甘特图(内附操作方法及实用模板)
8 年产品经验,我总结了这些持续高效研发实践经验 · 协同篇
Chapter7 : Network-Driven Drug Discovery
Named routes, the role of name in components
拒绝服务攻击DDoS介绍与防范
JWT actively checks whether the Token has expired
路由中的meta、params传参的一些问题(可传不可传,为空,搭配,点击传递多次参数报错)
数电快速入门(四)(组合逻辑电路的分析以及设计的介绍)
【uiautomation】微信好友列表获取(存储到txt中)
【PCBA方案设计】握力计方案