前言
今天刚好有空,跟大家聊聊如何学好算法进大厂。
前两天一个读者和我说,他坚持刷算法题2个月,薪资翻番去了他梦寐以求的大厂,期间面字节跳动还遇到了原题…其实据我所知目前国内的大厂和一些独角兽,已经越来越效仿硅谷公司的做法,通过编程定题面试,来考察数据结构和算法的扎实程度。
以我的经验来说,**对于新手来说,扎实的掌握一门语言是其一,其二就是要有基本的算法能力,这个非常重要。对于进阶的用户,更多技术栈的掌握就是必须的了。另外,还需要你学习高阶算法,掌握这些技术栈匹配的算法技能。**现在很多大厂技术面试的要求是:技术要好,计算机基础扎实,熟练掌握算法和数据结构,语言不重要,熟练度很重要。每一轮技术面试不只考算法,但一定会考算法。
为什么这几年算法成了其中必要的一个环节?因为考察算法的核心就是,看候选人是不是足够聪明!很多大厂的算法面试题一般对应的是 LeetCode 中级模式,一般会直接让你说思路或上手写代码。
要通过面试,你肯定得花时间好好准备。但是只靠刷题去提升算法能力,进度太慢,而且还容易抓不住重点很难坚持,并且没有完整的学习体系,也没人指导,导致最后的结果就是一知半解,浪费了大量的时间成本。
美团一面:
收到了HR的信息,通知我去面试,说实话真的挺紧张的。自己准备了近一个月的时间,很担心面试不过,到时候又后悔不该“裸辞”。
- 自我介绍
- spring的IOC,AOP原理
- springmvc的工作流程
- handlemapping接收的是什么
- 项目中你用到了MyBatis,说说#和$的区别
- MyBatis你写的XML怎么绑定对应的接口?namespace.id
- Spring有几种方式定义Bean
- git你用过哪些命令
- linux怎么在查找目录下的一个文件
- redis基本数据结构
- redis单线程模型
- 事务的四大特性
- 解释线程池的三个主要参数
- 具体的问项目中线程池如何使用的(这里因为有些忘记,导致扣了很久)
- AQS都有什么公共方法
- 那单例模式和prototype模式,spring都是怎么实现的
- 计算机网络应用层都有什么协议
美团二面
第二面问的挺多的内容,只记得个大概,所以也只能分享一个我所能记忆到的面试内容
- 描述从输入一个url到得到结果的过程
- springMVC的执行过程
- MVC设计模式
- static变量初始化在哪个阶段
- jvm堆中的内存区域分布
- 垃圾收集算法
- redis如何实现高并发
- synchronized是可重入的吗?是公平还是非公平
- 公平锁和非公平锁的区别、
- 项目中如何使用的redis
- MySQL的的默认隔离级别、防止了什么读
- SQL题:有一个学生表,有id和name,姓名有可能重复,查询出所有姓名重复的人的名字
- 四次挥手的过程
- 动态规划的特点
- 索引结构?为什么使用B+索引
- CAS原理?用CAS实现 两个线程给同一个变量赋值
- 为什么 Redis 需要把所有数据放到内存中
- mysql的主从复制机制
- 将阿拉伯数字转换成中文数字。如(int)123456->十二万三千四百五十六
这一面自我感觉比一面好很多,面试官态度很和蔼,就让我没有那么的紧张,让我稍等一下,我也不知道下一面是情况,或者有没有下一面。
美团三面
- 自我介绍
- 介绍一个你觉得难的项目
- 说一下sql做了什么优化
- 项目中如何使用的redis
- redis如何保持和mysql的数据一致性
- 说一下都有什么类型二叉树
- 代码题:构建一个二叉树,做前序的非递归遍历
- 数据库最大的表大概多大
- 了解哪些分布式的技术
- 最近在看什么书?说一说
面试官给出的建议是,如果代码再稍微优美一点就很好了,不过也没什么大问题。然后跟我说让我等一等,出去商量商量。哎,真的太难了~~~
交叉面
来了个其他部门更牛B的大佬,感觉自己要凉,我太难了~~~
- 项目介绍一下
- AQS介绍一下
- Java中有哪些锁机制
- 介绍一下ConcurrentHashMap
- 为什么项目中用Springboot
- 用过Spring事务吗?有哪些事务传播属性
- A方法上有@Transactional注解,B方法上也有@Transactional,在一个方法里(也有@Transactional注解)。先调用A,再调用B,B出现了异常,A是否能提交?如果不能,怎样能让A提交成功
- 缓存穿透了解吗?怎么解决
- 布隆过滤器了解吗?有什么问题>
整理了一份Java面试笔记。包括了:Java面试、Spring、JVM、MyBatis、Redis、MySQL、并发编程、微服务、Linux、Springboot、SpringCloud、MQ、Kafka 面试专题
需要全套面试笔记的【点击此处即可】即可获取
- 有A,B两个大的文件集合,记录了一些订单号,怎样找到A中有的但B中没有的订单号?使用布隆过滤器可以吗
- 一个方法上有@Transactional注解,里面调用了A(),B(),C()。其中B进行了网络调用,可能传输时间比较长,这样设计有什么问题?怎么解决
- MQ用过吗
- 最近在学什么