当前位置: 首页 > news >正文

二叉树相关算法

目录

    • 1 遍历二叉树
      • 1.1 前序遍历
      • 1.2 中序遍历
      • 1.3 后序遍历
      • 1.3 层序遍历

1 遍历二叉树

1.1 前序遍历

//前序遍历
void PreOrder(BTNode* root)
{
	if (root == NULL)
	{
		printf("N ");
		return;
	}
	printf("%d ", root->val);
	PreOrder(root->left);
	PreOrder(root->right);
}
#include <iostream>
#include <stack>
using namespace std;

struct BTNode {
    int val;
    BTNode* left;
    BTNode* right;
    BTNode(int x) : val(x), left(nullptr), right(nullptr) {}
};

// **前序遍历(非递归)**
void PreOrder(BTNode* root) {
    if (!root) return;

    stack<BTNode*> s;
    s.push(root);

    while (!s.empty()) {
        BTNode* node = s.top();
        s.pop();
        cout << node->val << " ";

        if (node->right) s.push(node->right); // 右子树先入栈
        if (node->left) s.push(node->left);   // 左子树后入栈
    }
}

1.2 中序遍历

//中序遍历
void InOrder(BTNode * root)
{
	if (root == NULL)
	{
		printf("N ");
		return;
	}
	InOrder(root->left);
	printf("%d ", root->val);
	InOrder(root->right);
}
// **中序遍历(非递归)**
void InOrder(BTNode* root) {
    stack<BTNode*> s;
    BTNode* curr = root;

    while (!s.empty() || curr) {
        while (curr) {  // 先走到最左
            s.push(curr);
            curr = curr->left;
        }
        curr = s.top(); s.pop();
        cout << curr->val << " ";  // 访问当前节点
        curr = curr->right;  // 转向右子树
    }
}

1.3 后序遍历

//后序遍历
void PostOrder(BTNode * root)
{
	if (root == NULL)
	{
		printf("N ");
		return;
	}
	InOrder(root->left);
	InOrder(root->right);
	printf("%d ", root->val);
}
// **后序遍历(非递归)**
void PostOrder(BTNode* root) {
    if (!root) return;

    stack<BTNode*> s, output;
    s.push(root);

    while (!s.empty()) {
        BTNode* node = s.top();
        s.pop();
        output.push(node);

        if (node->left) s.push(node->left);
        if (node->right) s.push(node->right);
    }

    while (!output.empty()) {
        cout << output.top()->val << " ";
        output.pop();
    }
}

1.3 层序遍历

#include <iostream>
#include <queue>
using namespace std;

struct BTNode {
    char data;
    BTNode* left;
    BTNode* right;
    BTNode(char x) : data(x), left(nullptr), right(nullptr) {}
};

// **层序遍历(BFS)**
void LevelOrder(BTNode* root) {
    if (!root) return;

    queue<BTNode*> q;
    q.push(root);

    while (!q.empty()) {
        BTNode* top = q.front();
        q.pop();
        cout << top->data << " ";

        if (top->left) q.push(top->left);
        if (top->right) q.push(top->right);
    }
}

相关文章:

  • DeepSeek与人工智能:技术演进、架构解析与未来展望
  • 如何解决ChatGPTplus/pro o1/o3模型无法识别图片或者文件,限制次数?
  • 将bin文件烧录到STM32
  • HOT100(1)
  • 【Linux文件IO】系统IO中API描述和基本使用
  • 【论文阅读】Cross-View Fusion for Multi-View Clustering
  • 商业计划 - 四维拆解ToB、ToC、ToG、ToVC:商业赛道的本质差异与战略选择
  • 浅谈树状数组算法
  • Type_ C和锂电池自切换电路
  • 圣奥获“突出贡献企业”和“强工业企业”等多项殊荣
  • 【Git】--- 初识Git Git基本操作
  • BaseActivity 和 BaseFragment 的现代化架构:ViewBinding 与 ViewModel 的深度整合
  • leetcode hot100特殊题型
  • 安装配置Anaconda
  • 前缀和算法第一弹(一维前缀和和二维前缀和)
  • c++图论(三)之图的遍历
  • 图解多头注意力机制:维度变化一镜到底
  • doris:安全概览
  • 【计算机视觉】工业表计读数(1)--基于关键点检测的读数识别方案
  • uboot源码结构
  • 城市更新·简报│中央财政支持城市更新,倾斜超大特大城市
  • 证据公布!菲律宾6人非法登上铁线礁活动
  • “即买即退”扩容提质,上海静安推出离境退税2.0版新政
  • 上汽集团一季度净利润30.2亿元,同比增长11.4%
  • 言短意长|新能源领军者密集捐赠母校
  • 药明康德一季度净利增长89%,在手订单增超四成至523亿元