二叉树程序遍历---框架--应用

二叉树程序遍历也就那样

学会二叉树的层序遍历框架。以下题目都可求解。

102.二叉树的层序遍历
107.二叉树的层次遍历II
199.二叉树的右视图
637.二叉树的层平均值
429.N叉树的前序遍历
515.在每个树行中找最大值
116.填充每个节点的下一个右侧节点指针(等于117)
117.填充每个节点的下一个右侧节点指针II

102.二叉树的层序遍历
在这里插入图片描述
层序遍历一个二叉树,就是从左到右一层一层的去遍历二叉树。
需要借用一个辅助数据结构即队列来实现,队列先进先出,符合一层一层遍历的逻辑,而是用栈先进后出适合模拟深度优先遍历也就是递归的逻辑。
而这种层序遍历方式就是图论中的广度优先遍历,只不过我们应用在二叉树上。
代码如下:这份代码也可以作为二叉树层序遍历的模板,以后再打后面的题目就靠它了。

class Solution{
public:
	vector<vector<int>> levelOrder(TreeNode *root){
		queue<TreeNode *> que;
		if(root != NULL){
			que.push(root);
		}
		vector<vector<int> > result;
		while( !que.empty()){
			int size = que.size();
			vector<int> vec;
			for(int i = 0; i < size; i++){
				TreeNode *node = que.front();
				que.pop();
				vec.push_back(node->val);
				if(node->left) que.push(node->left);
				if(node->right) que.push(node->right);
			}
			result.push_back(vec);
		}
		return result;
	}
};

此时我们就掌握了二叉树的层序遍历了,那么如下几道leetcode上的题目,只需要修改模板的一两行代码。
107. 二叉树的层次遍历 II
在这里插入图片描述
思路:只需将层序遍历的数组反转输出即可。

class Solution{
public:
	vector<vector<int>> levelOrder(TreeNode *root){
		queue<TreeNode *> que;
		if(root != NULL){
			que.push(root);
		}
		vector<vector<int> > result;
		while( !que.empty()){
			int size = que.size();
			vector<int> vec;
			for(int i = 0; i < size; i++){
				TreeNode *node = que.front();
				que.pop();
				vec.push_back(node->val);
				if(node->left) que.push(node->left);
				if(node->right) que.push(node->right);
			}
			result.push_back(vec);
		}
		reverse(result.begin(), result.end());
		return result;
	}
};

199. 二叉树的右视图
在这里插入图片描述
思路:层序遍历时,判断是否遍历到单层的最后一个元素,如果是就放进result数组。

class Solution {
public:
    vector<int> rightSideView(TreeNode* root) {
    	queue<TreeNode *> que;
    	if(root != NULL) que.push(root);
    	vector<int> result;
    	
    	while( !que.empty()){
    		int size = que.size();
    		for(int i = 0;i < size; i++){
    			TreeNode *node = que.front();
    			que.pop();
    			if( i == (size - 1) ) result.push_back(node->val);
    			if(node->left) que.push(node->left);
    			if(node->right) que.push(node->right);
    		}
    	}
    	return result;
    }
    
};

637. 二叉树的层平均值
在这里插入图片描述
思路:每一层遍历时并求和,然后再取一个平均值。

class Solution {
public:
    vector<double> averageOfLevels(TreeNode* root) {
				queue<TreeNode *> que;
				if( root != NULL ) que.push(root);
				vector<double> result;
				while( !que.empty()){
					int size = que.size();
					double sum = 0;
					for(int i = 0; i < size; i++){
						TreeNode *node = que.front();
						que.pop();
						sum += node->val;
						if(node->left) que.push(node->left);
						if(node->right) que.push(node->right);
					}
					result.push_back( sum / size);
				}
				return result;
    }
};

429. N叉树的层序遍历
在这里插入图片描述
思路:即是层序遍历,将2个孩子结点变成n个孩子,进行遍历。

class Solution {
public:
    vector<vector<int> > levelOrder(Node* root) {
				queue<Node *> que;
				if(root != NULL) que.push(root);
				vector<vector<int> > result;
				while( !que.empty()){
					int size = que.size();
					vector<int> vec;
					for(int i = 0; i < size; i++){
						Node *node = que.front();
						que.pop();
						for(int i = 0; i < node->children.size(); i++){
							if(node->children[i]) vec.push_back(node->children[i]);
						}
					}
					result.push_back(vec);
				}
				return result;
    }
};

515. 在每个树行中找最大值
在这里插入图片描述
思路:层序遍历时,每一层进行最大值比较。将最大值放入到result中。

class Solution {
public:
    vector<vector<int> > largestValues(TreeNode* root) {
				queue<TreeNode *> que;
				if(root != NULL) que.push(root);
				vector<int> result;
				while( !que.empty()){
					int size = que.size();
					int ans = INT_MIN;
					for(int i = 0; i < size; i++){
						TreeNode *node = que.front();
						que.pop();
						ans = max(ans, node->val);
						if(node->left) que.push(node->left);
						if(node->right) que.push(node->right);		
					}
					result.push_back(ans);
				}
				return result;
    }
};

116. 填充每个节点的下一个右侧节点指针
在这里插入图片描述
在这里插入图片描述
思路:依然是层序遍历,只不过在单层便利时记录一下本层的头部节点,然后在遍历的时候让前一个节点指向本节点。

class Solution {
public:
    Node* connect(Node* root) {
        queue<Node*> que;
        if (root != NULL) que.push(root);
        while (!que.empty()) {
            int size = que.size();
            vector<int> vec;
            Node* nodePre;
            Node* node;
            for (int i = 0; i < size; i++) {
                if (i == 0) {
                    nodePre = que.front(); // 取出一层的头结点
                    que.pop();
                    node = nodePre;
                } else {
                    node = que.front();
                    que.pop();
                    nodePre->next = node; // 本层前一个节点next指向本节点
                    nodePre = nodePre->next;
                }
                if (node->left) que.push(node->left);
                if (node->right) que.push(node->right);
            }
            nodePre->next = NULL; // 本层最后一个节点指向NULL
        }
        return root;

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值