代码随想录刷题——二叉树篇(九)

257. 二叉树的所有路径
迭代+回溯:

cpp 复制代码
class Solution{
public:
	void traversal(TreeNode* node,vector<int>& path,vector<string>& ans){
		path.push_back(node->val);
		if(!node->left&&!node->right){
			string sPath;
			for(int i=0;i<path.size()-1;i++){
				sPath += to_string(path[i]);
				sPath += "->";
			}
			sPath += to_string(path[path.size()-1]);
			ans.push_back(sPath);
		}
		if(node->left){
			traversal(node->left,path,ans);
			path.pop_back();
		}
		if(node->right){
			traversal(node->right,path,ans);
			path.pop_back();
		}
		return ;
	} 
	vector<string> binaryTreePaths(TreeNode* root) {
        vector<string> ans;
        vector<int> path;
		if(!root) return ans;
		traversal(root,path,ans);
		return ans;
    }
};

迭代+回溯:

cpp 复制代码
class Solution{
public:
	vector<string> binaryTreePaths(TreeNode* root){
		vector<string> ans;
		if(!root) return ans;
		queue<TreeNode*> qu;
		queue<string> qs;
		qu.push(root);
		qs.push(to_string(root->val));
		while(!qu.empty()){
			TreeNode* node=qu.front();
			qu.pop();
			string path=qs.front();
			qs.pop();
			if(!node->left&&!node->right){
				ans.push_back(path);
			} 
			if(node->right){
				qu.push(node->right);
				qs.push(path+"->"+to_string(node->right->val));
			}
			if(node->left){
				qu.push(node->left);
				qs.push(path+"->"+to_string(node->left->val));
			}
		}
		return ans;
	}
};

其他:

(1)递归新理解:想象一棵如下图所示的树,从NULL开始,分三种情况 向上分别思考。考虑终止处理逻辑出现在哪一层,以及需要的处理逻辑是什么样的。因为红框框起来的三个节点代表了递归中的三种情况:一是空节点,二是叶子节点,三是连接叶子节点的节点

这样的好处在于,三种节点的情况由简单复杂 ,同时也是递归本身的总体顺序(从下往上),便于理清递归的整体逻辑。

(3)递归和回溯:

a.递归和回溯要在一起

b.递归和回溯时,共享变量 就像是记录情况的进度条,有增有减

(4)迭代和回溯:

a.只要是回溯 ,就应该有记录情况的进度条

b.迭代时的回溯更像是复制了多次备份

迭代法这里用于遍历的容器适配器 必须和用于存储string的容器适配器一致,如果一个是queue、另一个是stack,顺序就不对了

(5)to_string()的使用

相关推荐
2401_831824964 小时前
基于C++的区块链实现
开发语言·c++·算法
We་ct4 小时前
LeetCode 918. 环形子数组的最大和:两种解法详解
前端·数据结构·算法·leetcode·typescript·动态规划·取反
愣头不青4 小时前
238.除了自身以外数组的乘积
数据结构·算法
人工智能AI酱4 小时前
【AI深究】逻辑回归(Logistic Regression)全网最详细全流程详解与案例(附大量Python代码演示)| 数学原理、案例流程、代码演示及结果解读 | 决策边界、正则化、优缺点及工程建议
人工智能·python·算法·机器学习·ai·逻辑回归·正则化
WangLanguager4 小时前
逻辑回归(Logistic Regression)的详细介绍及Python代码示例
python·算法·逻辑回归
m0_518019484 小时前
C++与机器学习框架
开发语言·c++·算法
一段佳话^cyx4 小时前
详解逻辑回归(Logistic Regression):原理、推导、实现与实战
大数据·算法·机器学习·逻辑回归
qq_417695054 小时前
C++中的代理模式高级应用
开发语言·c++·算法
xiaoye-duck5 小时前
《算法题讲解指南:动态规划算法--路径问题》--5.不同路径,6.不同路径II
c++·算法·动态规划
ambition202425 小时前
最大子数组和算法全解析:从暴力枚举到动态规划优化
数据结构·c++·算法