二叉树OJ做题报告

二叉树

  • [力扣LCR 145](#力扣LCR 145)
  • [力扣 226](#力扣 226)
    • [力扣 236](#力扣 236)

力扣LCR 145

判断对称二叉树

学到了:

  • node* p = new node{成员1,成员2};//申请一个node型结构体变量,并初始化成员
  • 二叉树层次插入可以先将数组保存到一个数组里,再根据数组下标递归插入
cpp 复制代码
TreeNode*bulidTree(int i){//i为数组下标
	if(i>n||a[i]==-1){//-1代表为空
		return nullptr;
	}
	TreeNode*node=new TreeNode{a[i],bulidTree(2*i),bulidTree(2*i+1)};
	return node;
}
  • new不需要头文件,malloc需要stdlib.h头文件
  • 无论在什么地方mallocnew,都必须释放,否则会导致内存泄漏
  • 内存分配和释放要配对,如:

int* p = new int; --> delete p;
int* arr = new int[2]; --> delete[] arr;
int* p = (int)malloc(sizeof(int)); -->free(p);

以后要注意:

  • 二叉树递归的出口要明确,不要漏掉了

力扣 226

学到了:

  • 层序遍历

    • 层序遍历是指按层次的顺序 从根结点向下 逐层进行遍历,且对同一层的结点为从左到右遍历
    • 基本思路:
    1. 将根结点 root 加入队列 q。
    2. 取出队首结点,访问它。
    3. 如果该结点有左孩子,将左孩子入队。
    4. 如果该结点有右孩子,将右孩子入队。
    5. 返回第2点,直到队列为空。
cpp 复制代码
queue<TreeNode*> q;	//注意这个队列存的是地址 
	q.push(root);		//根节点地址入队 
	while(!q.empty()){
		TreeNode*node=q.front();//取队首元素 
		q.pop();
		printf("%d ",node->val);//访问队首元素 
		if(node->left) {		//左子树非空
			q.push(node->left); 
		}
		if(node->right) {	   	//右子树非空 
			q.push(node->right);
		}
	}

以后要注意的:

  • 不要用脑子想递归的过程,递归都有返回值,像本题,返回左右孩子,直接交换左右孩子就是答案,不要模拟向下的过程,把递归函数想象成一个黑盒子,返回值就是你要的某个必要的值,直接用这个值计算就行
  • 写递归代码时从下往上想,基本情况处理好了想第二层怎么调用刚刚处理好的基本情况,以此递推

力扣 236

二叉树的最近公共祖先

这题与上面的题差不多,都是基于递归来写的,但是情况比较多,在纸上写好需要应对的情况就好了

学到了:

  • devc++遇到段错误(比如等待一段时间后输出没结果),可以直接点上面的√调试(如需输入的话先输入),它会直接定位到发生段错误的代码行上

以后要注意的:

  • 发生段错误且定位到代码行后,注意分清楚字母和数字(比如"i"和"1"),字母和数字在编程软件上显示是不同的
  • 题目情况多的情况下把所有情况写在纸上,再写代码
相关推荐
AI成长日志20 分钟前
【笔面试算法学习专栏】二分查找专题:力扣hot100经典题目深度解析
学习·算法·面试
lcreek23 分钟前
流量优化之道:Ford-Fulkerson 最大流算法
算法·
垫脚摸太阳32 分钟前
第 36 场 蓝桥·算法挑战赛·百校联赛---赛后复盘
数据结构·c++·算法
Aaswk44 分钟前
刷题笔记(回溯算法)
数据结构·c++·笔记·算法·leetcode·深度优先·剪枝
NAGNIP1 小时前
一文搞懂CNN经典架构-ResNet!
算法·面试
计算机安禾1 小时前
【数据结构与算法】第14篇:队列(一):循环队列(顺序存储
c语言·开发语言·数据结构·c++·算法·visual studio
Java_小白呀1 小时前
考研408数据结构(持续更新中...)
数据结构·考研
Frostnova丶1 小时前
(11)LeetCode 239. 滑动窗口最大值
数据结构·算法·leetcode
GoCoding1 小时前
YOLO-Master 与 YOLO26 开始
算法
VALENIAN瓦伦尼安教学设备1 小时前
设备对中不良的危害
数据库·嵌入式硬件·算法