144、二叉树的前序递归遍历

题解:

递归书写三要素:

1)确定递归函数的参数和返回值。要确定每次递归所要用到的参数以及需要返回的值

2)确定终止条件。操作系统也是用栈的方式实现递归,那么如果不写终止条件或者终止条件写的不对,都会导致出现栈溢出的情况。

3)确定单层递归逻辑后再开始递归。

此题目中,因为要打印遍历后的节点值,所以递归函数需要传入vector来存放节点值,也不需要返回值。终止条件就是当传入节点为NULL时,单层逻辑是将传入的节点的值记录下来。

代码如下:

复制代码
class Solution {
public:
    void Traversal(TreeNode* cur, vector<int> &vec){
        if(NULL == cur)  return;
        vec.push_back(cur->val);
        Traversal(cur->left,vec);       
        Traversal(cur->right,vec);       
    }
    vector<int> preorderTraversal(TreeNode* root) {
        vector<int> result;
        Traversal(root, result);
        return result;
    }
};

注意:

1)vector容器的使用,放入元素:vec.push_back()

2)注意传递的参数设置,要修改哪些参数就要传入哪些参数。

相关推荐
晨晖2几秒前
循环队列:出队
算法
LYFlied3 分钟前
【每日算法】LeetCode 70. 爬楼梯:从递归到动态规划的思维演进
算法·leetcode·面试·职场和发展·动态规划
最晚的py7 分钟前
聚类的评估方法
人工智能·算法·机器学习
业精于勤的牙11 分钟前
浅谈:算法中的斐波那契数(五)
算法·leetcode·职场和发展
液态不合群14 分钟前
查找算法详解
java·数据结构·算法
代码游侠15 分钟前
学习笔记——Linux进程间通信(IPC)
linux·运维·笔记·学习·算法
高洁0115 分钟前
DNN案例一步步构建深层神经网络(3)
python·深度学习·算法·机器学习·transformer
_dindong19 分钟前
笔试强训:Week -8
开发语言·c++·算法
LYFlied35 分钟前
【每日算法】LeetCode 105. 从前序与中序遍历序列构造二叉树
数据结构·算法·leetcode·面试·职场和发展
DanyHope40 分钟前
LeetCode 206. 反转链表:迭代 + 递归双解法全解析
算法·leetcode·链表·递归·迭代