Day91 | 灵神 | 二叉树 二叉树的最小深度
Day91 | 灵神 | 二叉树 二叉树的最小深度111.二叉树的最小深度111. 二叉树的最小深度 - 力扣(LeetCode) 后序遍历思路:1.递归函数意义 求得以传入参数t为根节点的树的最小深度 2.参数和返回值 1int get_depth(TreeNode *t) 返回值就是以t为根结点的树的最小深度 3.终止条件(边界条件) 如果我们碰到了空节点,那么它的深度肯定就是0了 12if(t==nullptr) return 0; 4.本层逻辑(非边界条件) 如果 node 是空节点,由于没有节点,返回 0。 如果 node 没有右儿子,那么深度就是左子树的深度加一,即 dfs(node)=dfs(node.left)+1。 如果 node 没有左儿子,那么深度就是右子树的深度加一,即 dfs(node)=dfs(node.right)+1。 如果 node...
Day90 | 灵神 | 二叉树 做题方法 二叉树的最大深度
Day90 | 灵神 | 二叉树 做题方法 二叉树的最大深度灵神的做题方法首先 类似于高中的整体法,将左右子树分别看为一个整体 其次 再次 最后 边界条件和非边界条件怎么算也得想清楚 并且在写代码之前还要想清楚为什么这样做是对的,可以用数学归纳法来说明 边界条件就类似于图中的1,而非边界条件就类似于图中的2 笔者觉得挺好的做题方法1.先想明白递归函数的含义,比如在下面的题中就是求以传入参数t为根节点的树的最大深度 2.想明白递归函数参数和返回值 3.想清楚递归函数结束条件,对应上面的边界条件 4.想清楚递归函数本层逻辑,对应上面的非边界条件 104.二叉树的最大深度104. 二叉树的最大深度 - 力扣(LeetCode) 思路: 1.递归函数意义 求以传入参数t为根节点的树的最大深度 2.参数和返回值 1int get_depth(TreeNode *t) 返回值就是以t为根结点的树的最大深度 3.终止条件(边界条件) 如果我们碰到了空节点,那么它的深度肯定就是0了 12if(t==nullptr) return...
26考研 | 王道 | 数据结构 | 第六章 图
第六章 图6.1....
刷题总结 | 灵神 | 链表章节
刷题总结 | 灵神 | 链表章节包含视频以及简介中的作业部分,但是不是链表章节所有的题单的题,那个太多了,把视频和作业过完一遍再说吧 标签: 链表 | Darlingの妙妙屋 题单 && 题解Day77 | 灵神 | 反转链表 反转链表 反转链表II K个一组翻转链表-CSDN博客 Day78 | 灵神 | 反转链表 两两交换链表中的节点-CSDN博客 Day79 | 灵神 | 反转链表 两数相加 两数相加II_反转链表 灵神-CSDN博客 Day80 | 灵神 | 反转链表 翻倍以链表形式表示的数字-CSDN博客 Day81 | 灵神 | 快慢指针 链表的中间结点 环形链表-CSDN博客 Day82 | 灵神 | 快慢指针 重排链表-CSDN博客 Day83 | 灵神 | 快慢指针 回文链表-CSDN博客 Day84 | 灵神 | 快慢指针 链表最大孪生和-CSDN博客 Day85 | 灵神 | 前后指针 删除链表中的节点 删除链表的倒数第 N 个结点-CSDN博客 Day86 | 灵神 | 前后指针 删除排序链表中的重复元素...
Day89 | 灵神 | 前后指针 合并两个链表
Day89 | 灵神 | 前后指针 合并两个链表1669.合并两个链表1669. 合并两个链表 - 力扣(LeetCode) 思路: 思路较为简单,就是一个模拟题 找到下标a的前一个结点并用p记录下来,继续遍历b-a+1的长度找到下标为b的节点,记录b的下一个节点为q 把list2接到p后,遍历list2,把末尾节点next指向q即可 完整代码: 123456789101112131415161718192021222324252627282930class Solution {public: ListNode* mergeInBetween(ListNode* list1, int a, int b, ListNode* list2) { ListNode *t=new ListNode; t->next=list1; ListNode *p=t; int length=b-a+1; //找到下标为a的结点的前一节点 while(a--) ...
Day88 | 灵神 | 前后指针 移除链表元素 从链表中移除结点
Day88 | 灵神 | 前后指针 移除链表元素 从链表中移除结点2487.从链表中移除结点2487. 从链表中移除节点 - 力扣(LeetCode) 迭代思路: 凡是你觉得反转链表以后好做的都要毫不犹豫反转链表 这道题是因为如果左边的数都比右边这一个数小的话,我们很难找到从哪个结点开始删除 比如[1,2,3,4,5,6,7,8,9,13],1-9全是要删的,我们不知道从哪里开始进行循环 但是反转以后就很简单了 [13,1,2,3,4,5,6,7,8,9],13之后都是要删的,而且13可作为要删除节点的前一个结点,所以翻转后会好做很多 到这里也知道了其实这道题是倒着找最大值,所以反转后会比较好做,因为反转后变成正着找最大值 完整代码: 1234567891011121314151617181920212223242526272829303132class Solution {public: //206.反转链表 ListNode *reverseList(ListNode *head) { ListNode *pre =...
Day87 | 灵神 | 前后指针 移除链表元素 从链表中移除在数组中存在的节点
Day87 | 灵神 | 前后指针 移除链表元素 从链表中移除在数组中存在的节点203.移除链表元素203. 移除链表元素 - 力扣(LeetCode) 思路: 就是一道easy题目,思路并不难想,就从前往后遍历就行 完整代码: 123456789101112131415161718class Solution {public: ListNode* removeElements(ListNode* head, int val) { ListNode *t=new ListNode; t->next=head; ListNode *p=t; while(p->next) if(p->next->val==val) { ListNode *temp=p->next; p->next=p->next->next; ...
Day86 | 灵神 | 前后指针 删除排序链表中的重复元素 删除排序链表中的重复元素II
Day86 | 灵神 | 前后指针 删除排序链表中的重复元素 删除排序链表中的重复元素II83.删除排序链表中的重复元素83. 删除排序链表中的重复元素 - 力扣(LeetCode) 思路: 就是一道easy题目,思路并不难想,笔者是用两个指针,一个l一个r,他们之间相隔1,然后如果两个的值相等就把r所指向的节点给删了,然后更新r为r的下一个结点。如果值不相等,那自然一起往后走 也可以和灵神一样用一个指针,代码更简洁,但是我感觉两根指针可以把要做的事情想得更清楚一点? 完整代码: 1234567891011121314151617181920212223242526272829303132333435363738394041/*class Solution {public: ListNode* deleteDuplicates(ListNode* head) { if(head==nullptr) return head; ListNode* l=head; ListNode*...
Day85 | 灵神 | 前后指针 删除链表中的节点 删除链表的倒数第 N 个结点
Day85 | 灵神 | 前后指针 删除链表中的节点 删除链表的倒数第 N 个结点237. 删除链表中的节点237. 删除链表中的节点 - 力扣(LeetCode) 思路: 把下一个结点的值复制到当前结点,那当前结点就是下一个结点的前一个结点,然后删除下一个结点即可 完整代码: 1234567891011class Solution {public: void deleteNode(ListNode* node) { *node=*(node->next); /* 相当于 node->val=node->next->val node->next=node->next->next */ }}; 19. 删除链表的倒数第 N 个结点19. 删除链表的倒数第 N 个结点 -...
Day84 | 灵神 | 快慢指针 链表最大孪生和
Day84 | 灵神 | 快慢指针 链表最大孪生和2130.链表最大孪生和2130. 链表最大孪生和 - 力扣(LeetCode) 思路: 比昨天的还要简单,还是一样的思路,找中间节点然后反转链表然后相加 完整代码: 1234567891011121314151617181920212223242526272829303132333435363738class Solution {public: // 876. 链表的中间结点 ListNode* middleNode(ListNode* head) { ListNode* slow = head, *fast = head; while (fast && fast->next) { slow = slow->next; fast = fast->next->next; } return slow; } // 206....