队列的例题和总结 0. 目录 栈实现队列 队列实现栈 滑动窗口最大值 1. 栈实现队列 FIFO和FILO,相当于+-号,互转都是利用"负负得正"的原理. 官方解答中第二种思路很6,按需反转,这样摊还分析下来,复杂度变成了O(1) class MyQueue { private: stack<int> s1; stack<int> s2; public: /** Initialize your data structure here. */ MyQueue()…
链表的例题和总结 0. 目录 环形链表 1. 环形链表 题目: https://leetcode-cn.com/problems/linked-list-cycle/ 看了别人的思路真是感概万千,思路这个东西啊,哈哈哈 官方方法1: 哈希表 官方方法2: 快慢指针 奇葩方法1: 标记访问过的节点(会破坏链表) 奇葩方法2: 倒因为果法 1.1 哈希表 略 1.2 快慢指针 思路就是田径场的追击问题, 如果有环, 那么跑得快的一定会碰到跑的慢的. 跑得快的一次走两步, 跑得慢的走一步. fast=…
常规题总结 0. 目录 两数之和 1. 两数之和 耗时4ms(98.82%),内存6.2m. 两数之和--寻找中值向两边扩散法 1.1 思路 思路很简单,就是先找数组中target/2的前后两个值,然后慢慢向两边扩散. 1.2 示例 [0,2,4,5,8] target为7 先找7/2=3.5前后的,也就是2和4这两个,获取其指针,front指向2,back指向4 2+4<7,所以back++,也就是指向5 2+5==7,所以成功返回 1.3 源码 int* twoSum(int* number…
堆和优先队列 堆的简介, 是一种二叉树, 有最大堆和最小堆miniheap. 通常用于构建优先队列. 0. 目录 数据流中的第K大元素 1. 数据流中的第K大元素 数据流中的第K大元素 复杂度为log2(N) class KthLargest { private: priority_queue<int, vector<int>, greater<int> > buf;//最小堆 int mk; public: KthLargest(int k, vector<in…
栈的例题和总结 0. 目录 有效的括号 栈实现队列(这个参见队列) 1. 有效的括号 static int top = 0; static char* buf = NULL; void stack(int size){ top = size; buf = (char*)malloc(size+1); buf[size] = '\0'; } void push(char c) {buf[--top] = c; } char pop() {return buf[top++];} bool isVal…
Given a linked list, rotate the list to the right by k places, where k is non-negative. Example 1: Input: 1->2->3->4->5->NULL, k = 2 Output: 4->5->1->2->3->NULL Explanation: rotate 1 steps to the right: 5->1->2->3-&g…
问题描述 给定一个二叉树,原地将它展开为链表. 例如,给定二叉树 1 / \ 2 5 / \ \ 3 4 6 将其展开为: 1 \ 2 \ 3 \ 4 \ 5 \ 6 解题思路 二叉树的一些算法题都可以使用递归来解决,这道题也不例外. 首先对空指针应该直接返回. 然后递归将左子树展开为链表 1 / \ 2 5 \ \ 3 6 \ 4 再递归将右子树展开为链表 1 / \ 2 5 \ \ 3 6 \ 4 再然后暂存右子树,将左子树链接到根节点右孩子上,切记左孩子要置空! 1 5 \ \ 2 6 \…
Merge k Sorted Lists 问题简介:合并k个已排序的链表并将其作为一个排序链表返回. 举例: 输入: [ 1->4->5, 1->3->4, 2->6 ] 输出: 1->1->2->3->4->4->5->6 链表结构: 解法一: 建立一个集合,遍历所有链表,将其元素添加到集合中,将集合通过数组的方式升序排序,将其添加到一个新的链表中并返回 复杂度分析: 时间复杂度:o(n2)外层遍历一遍数组内层遍历链表的元素,即双层…
Merge Two Sorted Lists 问题简介:合并两个已排序的链表并将其作为新链表返回 举例: 输入: 1->3->5, 1->2->4 输出: 1->1->2->3->4->5 链表结构: 解法一: 定义一个头节点,遍历一遍两个链表,每次比较两个节点的值,添加值小的节点,注意非空判断 复杂度分析: 时间复杂度:o(n) 遍历一遍两个链表的长度 空间复杂度:o(n)定义一个变量,定义两个链表长度的节点 小白刷题之路,请多指教— — 要么大器晚…
Reverse a singly linked list. Example:           Input: 1->2->3->4->5->NULL                   Output: 5->4->3->2->1->NULL Follow up: A linked list can be reversed either iteratively or recursively. Could you implement both? 解…