当前位置:网站首页>如何将二叉搜索树转化为一个有序的双向链表(原树上修改)
如何将二叉搜索树转化为一个有序的双向链表(原树上修改)
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;
}
}
边栏推荐
猜你喜欢
随机推荐
LayaBox---knowledge point
知识分享|如何设计有效的帮助中心,不妨来看看以下几点
27. Dimensionality reduction
stm32mp157系统移植 | 移植ST官方5.10内核到小熊派开发板
How to train a deep learning model?
STP --- 生成树协议
伺服电机矢量控制原理与仿真(1)控制系统的建立
某男子因用本地虚拟机做压测,惨遭字节面试官当场嘲笑
DGL安装教程
1.读写点云文件
C语言知识大全(一)——C语言概述,数据类型
matlab drawing
拒绝服务攻击DDoS介绍与防范
for 循环中的 ++i 与 i++
3、IO流之字节流和字符流
web漏洞扫描器-awvs
括号匹配
Three ways to set a specific device UWP XAML view
命名路由、组件中name的作用
dotnet enables JIT multi-core compilation to improve startup performance