leetcode探索中级算法
leetcode探索中级答案汇总:
https://leetcode-cn.com/explore/interview/card/top-interview-questions-medium/
1)数组和字符串:
leetcode 15 三数之和(medium)排序+双指针
leetcode73 矩阵置零 (medium) 空间节省技巧
leetcode 49 字母异位词分组(medium)排序+哈希
leetcode 3 无重复字符的最长子串(medium) DP
leetcode5 最长回文子串(medium)DP
leetcode334 递增的三元子序列(meidum)双指针
2)链表:
leetcode 2 两数相加(medium)链表
leetcode 160相交链表 (easy)哈希、链表、双指针
leetcode 328 奇偶链表 (easy)双指针
3)树和图:
3.1)二叉树的后序遍历迭代法较为困难,使用space O(1)的马拉车算法也并不容易,都属于hard问题;
leetcode 102二叉树的层序遍历 (medium) 迭代、BFS
leetcode 144二叉树的前序遍历 (medium) 迭代、递归、DFS
leetcode 94二叉树的中序遍历 (medium) 迭代、递归、DFS
3.2)二叉树性质相关;
leetcode 103二叉树的锯齿形层次遍历 (medium)迭代、栈、BFS
leetcode 105从前序与中序遍历序列构造二叉树 (medium)递归、遍历
leetcode 116填充每个节点的下一个右侧节点指针 (medium)迭代遍历、BFS
3.3)关于二叉搜索树,一般是二叉树的遍历方法+二叉搜索树的性质;
leetcode 230二叉搜索树中第k小的元素 (medium)BST性质、迭代、递归、DFS
3.4)关于图的问题一般使用一般性的DFS,但有的问题加上并查集方法会极大的简化问题;
leetcode 200岛屿的个数 (medium) 并查集,DFS
4)回溯算法
4.1)这三个题目都为全部排列的问题,每次必定排列一个元素
leetcode 17电话号码的数字组合(medium)DFS,递归,回溯
leetcode 22括号生成(medium)DFS,递归,回溯
leetcode 46. 全排列(medium)DFS,递归,回溯
leetcode 51 N皇后问题 (hard)DFS,递归,回溯
4.2)前三个题目每次都会选择排列一个元素,而78问题子集第一次不push第二次push元素,因此得到一个序列的所有子集,子集每次两个分支因此总共O(2^n)
leetcode 78子集 (medium)DFS,递归,回溯,不一定每次push
4.3)图搜索
leetcode 79 单词搜索(medium)DFS、回溯、剪枝
4.4)全排列的另一种解法:
leetcode 31下一个排列 (medium)
5)排序和搜索
leetcode 75颜色分类(medium)计数排序
leetcode 347前k个高频元素(medium)哈希map、小顶堆
leetcode 215 第K个最大的元素(medium)小顶堆
leetcode 34在排序数组中查找元素的第一个和最后一个位置(medium)二分查找(lower_bound)
leetcode 56区间合并(medium)快速排序
leetcode 33搜索旋转排序数组 (medium)二分查找
6)动态规划
leetcode 55 跳跃游戏 (medium)dp[i]=max(dp[i-1],nums[i]+i)贪心
leetcode 62. 不同路径 (medium)dp[i][j]=dp[i][j-1]+dp[i-1][j];
leetcode 322. 零钱兑换 (medium)dp[i]=min(dp[i],1+dp[i-coins[j]])
leetcode 300. 最长上升子序列 (medium)if(j<i&&nums[j]<nums[i]) dp[i]=max(dp[i],dp[j]+1)、二分查找
7)设计问题
leetcode 297二叉树的序列化与反序列化 (hard)层序遍历、迭代;先序遍历、递归
8)数学问题
leetcode 202 快乐数(easy)
leetcode172 阶乘后的零 (easy)
leetcode171 Excel列表序列号(easy)
leetcode 50. Pow(x, n) (medium)分治法
leetcode 69. x 的平方根(easy)牛顿法、二分法
leetcode 29两数相除(medium)位运算、数学
leetcode 166分数到小数(medium)位运算、数学
9)其他类型
leetcode 371两整数之和(easy)位运算
leetcode 169求众数(easy)摩尔投票、stack
leetcode 150 逆波兰表达式求值(medium)stack
leetcode 621 任务调度器 Task Scheduler(medium)Greedy
leetcode探索中级算法的更多相关文章
- LeetCode探索初级算法 - 动态规划
LeetCode探索初级算法 - 动态规划 今天在LeetCode上做了几个简单的动态规划的题目,也算是对动态规划有个基本的了解了.现在对动态规划这个算法做一个简单的总结. 什么是动态规划 动态规划英 ...
- leetcode探索高级算法
C++版 数组和字符串 正文 链表: 正文 树与图: 树: leetcode236. 二叉树的最近公共祖先 递归(先序) leetcode124二叉树最大路径和 递归 图: leetcode 547朋 ...
- FreeCodeCamp 中级算法(个人向)
freecodecamp 中级算法地址戳这里 Sum All Numbers in a Range 我们会传递给你一个包含两个数字的数组.返回这两个数字和它们之间所有数字的和. function su ...
- 72【leetcode】经典算法- Lowest Common Ancestor of a Binary Search Tree(lct of bst)
题目描述: 一个二叉搜索树,给定两个节点a,b,求最小的公共祖先 _______6______ / \ ___2__ ___8__ / \ / \ 0 _4 7 9 / \ 3 5 例如: 2,8 - ...
- FCC中级算法(上)
在学习FCC中级算法这一块,自己遇到了很多问题,通过RSA也慢慢把问题解决了,发现每一个问题都会有很多的解决思路,因此把自己想到的一些思路记录到这里. 1. Sum All Numbers in a ...
- 用Javascript方式实现LeetCode中的算法(更新中)
前一段时间抽空去参加面试,面试官一开始让我做一道题,他看完之后,让我回答一下这个题的时间复杂度并优化一下,当时的我虽然明白什么是时间复杂度,但不知道是怎么计算的,一开局出师不利,然后没然后了,有一次我 ...
- FCC编程题之中级算法篇(下)
介绍 本篇是"FCC编程题之中级算法篇"系列的最后一篇 这期完结后,下期开始写高级算法,每篇一题 目录 1. Smallest Common Multiple 2. Finders ...
- FCC编程题之中级算法篇(中)
介绍 接着上次的中级算法题 目录 1. Missing letters 2. Boo who 3. Sorted Union 4. Convert HTML Entities 5. Spinal Ta ...
- FCC编程题之中级算法篇(上)
介绍 FCC: 全称为freeCodeCamp,是一个非盈利性的.面向全世界的编程练习网站.这次的算法题来源于FCC的中级算法题. FCC中级算法篇共分为(上).(中).(下)三篇.每篇各介绍7道算法 ...
随机推荐
- Hadoop 上Hive 的操作
数据dept表的准备: --创建dept表 CREATE TABLE dept( deptno int, dname string, loc string) ROW FORMAT DELIMITED ...
- 第九章、python文件的两种用途
目录 第九章.python文件的两种用途 一.用途 第九章.python文件的两种用途 一.用途 当前运行的文件(脚本) 被导入的文件(模块) # aaa.py x = 1 def f1(): pri ...
- Java语言基础(8)
1 数组(二) 1)for-each循环:增强的for循环,JDK1.5推出的,用来输出数组和集合中每一个元素的值. for(数据类型 变量 : 数组名){ 变量:临时保存元素的值 } 数据类型必须跟 ...
- Hdu 2147 巴什博弈 PN图
P:先手必输 N:先手必胜 PN图规则:如果一个点能转换到的所有点都是N,那么此点状态为P.若能转化到一个P,即使对手面临必输状态,此点为N. 然后找规律就行 #include<bits/s ...
- nodejs研发环境
https://blog.csdn.net/angl129/article/details/90696251
- 清北学堂dp图论营游记day6
xysq主讲: 求点双和边双代码: 对所有点进行染色,如果存在一种方案使得相邻的点不同色,那么他就是个二分图. 二分图两种求法,1,dfs求增广路. 2,网络流:最大流=最小割 差分约束: 下午又要考 ...
- Java一致性Hash算法的实现
哈希hashhash的意思是散列,目的将一组输入的数据均匀的分开.打散,往往用来配合路由算法做负载均衡,多用在分布式系统中.比如memcached它只提供了K V的存储.读取,如果使用了多台memca ...
- zeromq实践
zeromq简介 zeroMQ不是TCP,不是socket,也不是消息队列,而是这些的综合体. ZeroMQ以嵌入式网络编程库的形式实现了一个并行开发框架(concurrency framework) ...
- vue项目搭建和开发流程 vue项目配置ElementUI、jQuery和Bootstrap环境
目录 一.VUE项目的搭建 1. 环境搭建 2. 项目的创建和启动 二. 开发项目 1. 配置vue项目启动功能 2. 开发vue项目 (1)项目文件的作用 (2)vue项目开发流程 (3)vue项目 ...
- 王某的NLP之路前言
感谢基友jayjay和海英学姐的指路,其实我的方向一直比较迷茫. 因为自己是会计学出身的,前三年也没接触编程,第一次接触还是在2016年,尝试用聚宽的量化接口,当时顺便学了python 的一点知识. ...