【题解】二叉搜索树与双向链表

二叉搜索树与双向链表

题目链接:二叉搜索树与双向链表

解题思路1:递归+中序遍历

首先题目最后要求的是一个的递增的双向链表,而二叉搜索树也是一类非常有特色的树,它的根节点大于所有左侧的节点,同时又小于所有右侧的节点,如果我们按照左中右去遍历这颗二叉树,恰巧得到的就是一个递增序列

题目同时要求不要创建新的节点,这样我们就需要在原有树上进行操作,树有左右节点指针,双向链表有前后两个指针,正好一一对应,我们修改指针指向,结合中序遍历,得到一颗递增的双向链表

代码如下:

cpp 复制代码
	TreeNode* head = nullptr;
	TreeNode* pre = nullptr;
    TreeNode* Convert(TreeNode* pRootOfTree) {
        if(pRootOfTree == nullptr) return nullptr;//递归的结束条件
		Convert(pRootOfTree->left);//递归到最左节点,是最小值
		if(pre == nullptr){
			//此时pRootOfTree是最左节点,是链表的head
			//初始化head和pre
			head = pRootOfTree;
			pre = pRootOfTree;
		}else{
			//pre是每一个pRootOfTree的前驱节点
			pre->right = pRootOfTree;
			pRootOfTree->left = pre;
			pre = pRootOfTree;
		}
		Convert(pRootOfTree->right);
		return head;
    }

解题思路2:非递归+栈

我们利用栈先进后出的特性,来模拟中序遍历出所有元素,先让所有左侧的元素进栈,再依次取出其父节点,再找该节点的右节点,将节点进行连接,连接方式和上一种思路一样

cpp 复制代码
    TreeNode* Convert(TreeNode* pRootOfTree) {
		if(pRootOfTree == nullptr) return nullptr;
        TreeNode* head = nullptr;
		TreeNode* pre = nullptr;
		stack<TreeNode*> s;
		while(pRootOfTree!=nullptr || !s.empty()){
			while(pRootOfTree!=nullptr){
				s.push(pRootOfTree);
				pRootOfTree = pRootOfTree->left;
			}
			pRootOfTree = s.top();
			s.pop();
			if(pre == nullptr){
				head = pRootOfTree;
				pre = pRootOfTree;
			}else{
				pre->right = pRootOfTree;
				pRootOfTree->left = pre;
				pre = pRootOfTree;
			}
			pRootOfTree = pRootOfTree->right;
		}
		return head;
    }
相关推荐
良木生香1 小时前
【C++初阶】C++编程基石:编码表&&STL的入门指南
c语言·开发语言·数据结构·c++·算法
达帮主1 小时前
19.1 C语言链表 -- 简单
c语言·开发语言·链表
cwplh3 小时前
平衡树学习笔记
数据结构·笔记·学习·算法
Not Dr.Wang4224 小时前
基于matlab的控制系统奈氏图及其稳定性分析
数据结构·算法·matlab
老约家的可汗5 小时前
深入浅出:Map与Set的核心原理与使用场景
数据结构·算法
承渊政道5 小时前
【递归、搜索与回溯算法】(穷举vs暴搜vs深搜vs回溯vs剪枝:一文讲清概念与用法)
数据结构·c++·算法·决策树·深度优先·剪枝·宽度优先
我不是懒洋洋5 小时前
【数据结构】栈和链表基本方法的实现
c语言·开发语言·数据结构·c++·链表·青少年编程·ecmascript
澈2075 小时前
C++ string操作指南:从入门到精通
数据结构·c++·算法
算法鑫探13 小时前
闰年判断:C语言实战解析
c语言·数据结构·算法·新人首发
木子墨51614 小时前
LeetCode 热题 100 精讲 | 并查集篇:最长连续序列 · 岛屿数量 · 省份数量 · 冗余连接 · 等式方程的可满足性
数据结构·c++·算法·leetcode