代码随想录算法训练营Day14|理论基础● 递归遍历 ● 迭代遍历● 统一迭代

从今天开始正式进入到二叉树章节,因为今天的内容我在学校就已经全部学过了,所以今天就是简单的说一下,题目就不放上来了,都是简单的二叉树的前中后序遍历的递归写法和迭代写法;

递归写法不用多说,来看迭代的具体代码

 vector<int> preorderTraversal(TreeNode* root) {
        if(root==NULL) return {};
        vector<int> vec;
	stack<TreeNode*> st;
	st.push(root);
	while (st.empty() == false) {
		TreeNode* node = st.top();
		st.pop();
        if(node!=NULL)
		vec.push_back(node->val);
		if (node->right != NULL) {
			st.push(node->right);
		}
		if (node->left != NULL) {
			st.push(node->left);
		}
	}
	return vec;
    }

这是前序遍历的迭代法的写法,注意这里是先将右子树加入到栈中,再将左子树加入到栈中,因为这样才能先弹出左节点,再弹出右节点

 vector<int> postorderTraversal(TreeNode* root) {
        if(root==NULL) return {};
        vector<int> vec;
	stack<TreeNode*> st;
	st.push(root);
	while (st.empty() == false) {
		TreeNode* node = st.top();
		st.pop();
		vec.push_back(node->val);
		if (node->left != NULL) {
			st.push(node->left);
		}
		if (node->right != NULL) {
			st.push(node->right);
		}
	}
	for (int i = 0; i < vec.size()/2; i++) {
		swap(vec[i], vec[vec.size() - i - 1]);
	}
	return vec;
	
    }

这是后序遍历的迭代法,这里值得注意的是,将左右结点进栈的顺序改变之后,他的顺序就是中右左,再将数组翻转过来就是左右中了

vector<int> inorderTraversal(TreeNode* root) {
       vector<int> vec;
	stack<TreeNode*> st;
	TreeNode* node = root;
	while (st.empty() == false || node != NULL) {
		if (node != NULL) {
			st.push(node);
			node = node->left;
		}
		else {
			node = st.top();
			st.pop();
			vec.push_back(node->val);
			node = node->right;
		}
	}
	return vec;
    }

这是中序遍历的迭代法,这里就是再该节点不为空的时候,不断将其加入到栈中,直到他为空的时候,代表此时我的左节点已经遍历完了,就将栈顶元素弹出,然后加入到数组中,再将node赋为该节点的右孩子,因为是中序遍历,遍历顺序是左中右,然后一直进行该操作直至栈为空

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值