当前位置:网站首页>如何将二叉搜索树转化为一个有序的双向链表(原树上修改)
如何将二叉搜索树转化为一个有序的双向链表(原树上修改)
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;
}
}
边栏推荐
猜你喜欢

【uiautomation】微信好友列表获取(存储到txt中)

After encountering MapStruct, the conversion between PO, DTO and VO objects is no longer handwritten

8 年产品经验,我总结了这些持续高效研发实践经验 · 协同篇

C语言之实现扫雷小游戏

JdbcTemplate概述和测试

拒绝服务攻击DDoS介绍与防范

数电快速入门(五)(编码器的介绍以及通用编码器74LS148和74LS147的介绍)

PRIMAL: Pathfinding via Reinforcement and Imitation Multi-Agent Learning Code Analysis

Spss-一元回归实操

无代码平台字段设置:基础设置入门教程
随机推荐
LayaBox---TypeScript---结构
【PCBA方案设计】握力计方案
[Data Mining] Written Exam Questions for Sohu Data Mining Engineers
AtCoder Beginner Contest 262 D - I Hate Non-integer Number
Red team kill-free development practice of simulated confrontation
[2022 Hangzhou Electric Multi-School 5 1003 Slipper] Multiple Super Source Points + Shortest Path
两种白名单限流方案(redis lua限流,guava方案)
deepstream多相机显示布局
Data warehouse (1) What is data warehouse and what are the characteristics of data warehouse
[Academic related] Tsinghua professor persuaded to quit his Ph.D.:I have seen too many doctoral students have mental breakdowns, mental imbalances, physical collapses, and nothing!...
matlab 画图
括号匹配
PowerCLi import license to vCenter 7
PCBA scheme design - kitchen voice scale chip scheme
【PCBA program design】Grip dynamometer program
dotnet enables JIT multi-core compilation to improve startup performance
dotnet 启动 JIT 多核心编译提升启动性能
visual studio 2015 warning MSB3246
数电快速入门(五)(编码器的介绍以及通用编码器74LS148和74LS147的介绍)
C语言知识大全(一)——C语言概述,数据类型