2.9 KiB
牛客网拼多多面试题
- 一亿个数找出top 100(手写)
先对数据进行分分割,然后构建一个长度为100的小顶堆。
-
寻找结点的共同双亲
-
一个数组 找出所有和为n的种类数目
先对数组进行排序,然后使用一前一后两个指针,慢慢找到和为n的种类数目
- 给定两个稀疏矩阵 求乘法 要优化后的
作者:团子s1 链接:https://www.nowcoder.com/discuss/94066?type=2&order=0&pos=13&page=1 来源:牛客网
- 在纸上写一个一个链表排序,并拍照发过去(实现了一个冒泡的链表排序,被鄙视之,嫌弃空间复杂度和时间复杂度)
链表排序,使用快慢指针,链表分割,然后融合。
- 在纸上写一个Binary Search Tree的建立函数
二叉搜索,二分法
- 说一说事务的ACID,其中把事务的隔离性让我单独详细解释了一遍
数据库隔离:
事务隔离级别 | 脏读 | 不可重复读 | 幻读 |
---|---|---|---|
读未提交(read-uncommitted) | 是 | 是 | 是 |
不可重复读(read-committed) | 否 | 是 | 是 |
可重复读(repeatable-read) | 否 | 否 | 是 |
串行化(serializable) | 否 | 否 | 否 |
- 说一说幻影读
线程A读取表的内容,线程B刚好在线程A读取的内容作了新增或者修改的操作。
- 说一说HashMap和concurrentHashMap
常见问题
- 说一说如何解决hash冲突的,以及如果冲突了,怎么在hash表中找到目标值
链表法,再哈希法
- 说一说jdk1.8中,对hashMap的优化
hash 链表长度大于8就改为红黑树
- 说一说jdk1.8中对concurrentHashMap的优化
使用synchronized + cas,1.7 是用的Segment锁
1、手撕小顶堆
参考堆排序的内容
2、剑指offer题目
8.16 重新刷了一遍
拼多多: 逻辑思维,编程,项目经验,科研能力 java、python
推荐算法: 分析商品的品质对用户后续的影响,
=============8.19,拼多多线下面试=======
作者:讨饭好艰难 链接:https://www.nowcoder.com/discuss/95940 来源:牛客网
一面:
-
首先讲项目,然后说了蛮长的时间,基于项目内容的提问较少
-
B+ 树的原理
-
问了JAVA的GC内容,如何查到代码那里出现问题
-
说了计算机网络从应用层到物理层的用处等等
-
算法题,求一个字符串的最长连续不重复的子字符串。用了贪心算法找,算不难,后面时间不够,就没有手撕了。
二面:
-
还是讲项目,然后这个面试官问了项目的实现逻辑,问的比较细,基本上应付过去了
-
HTTP和TCP的区别
-
HTTP和HTTPS的区别
-
访问一个网站的过程
-
手撕一个算法,输入有序的数组,然后把前K位依次追加到后面,求最小的那个数。其实就是二分查找,比较简单
-
数据库的存储原理 B+ 树
-
B+ 树和AVL树在单点查询的情况下的效率区别。