当前位置:网站首页>如何将二叉搜索树转化为一个有序的双向链表(原树上修改)
如何将二叉搜索树转化为一个有序的双向链表(原树上修改)
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;
}
}
边栏推荐
- SAP ABAP OData 服务如何支持 $select 有选择性地仅读取部分模型字段值试读版
- jekyll 在博客添加流程图
- [21 days learning challenge - kernel notes] (2), based in the device tree
- 经验分享|盘点企业进行知识管理时的困惑类型
- adb控制常用命令
- 【2022杭电多校5 1012题 Buy Figurines】STL的运用
- 数电快速入门(一)(BCD码和三种基本逻辑运算的介绍)
- 【一起学Rust | 进阶篇 | Service Manager库】Rust专用跨平台服务管理库
- 实战:10 种实现延迟任务的方法,附代码!
- stm32mp157系统移植 | 移植ST官方5.10内核到小熊派开发板
猜你喜欢
随机推荐
【分布式】分布式ID生成策略
LayaBox---TypeScript---Problems encountered at first contact
拒绝服务攻击DDoS介绍与防范
【1403. 非递增顺序的最小子序列】
香港暂停进口俄罗斯部分地区禽肉及禽类产品
【C语言】指针和数组的深入理解(第三期)
buu web
bracket matching
proe和creo的区别有哪些
【手把手教你使用STM32HAL库的串口空闲中断】
Zynq Fpga图像处理之AXI接口应用——axi_lite接口使用
idea2021版本添加上一步和下一步操作到工具栏
Chapter7 : Network-Driven Drug Discovery
LayaBox---知识点
Android 面试——如何写一个又好又快的日志库?
Re24:读论文 IOT-Match Explainable Legal Case Matching via Inverse Optimal Transport-based Rationale Ext
链路聚合技术及VRRP
2、字符集-编码-解码
Spss-系统聚类手算实操
用 Excel 爬取网络数据的四个小案例









