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