最新这400道面试题,决定了你去BAT还是TMD,花了6个月肝完阿里技术官的笔记

最后

分布式技术专题+面试解析+相关的手写和学习的笔记pdf

还有更多Java笔记分享如下:

image

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

in data;
struct node* next;
node(int d):data(d), next(NULL){}
}node;

void reverse(node* head)
{
if(NULL == head || NULL == head->next){
return;
}

node* prev=NULL;
node* pcur=head->next;
node* next;

while(pcur!=NULL){
if(pcur->next==NULL){
pcur->next=prev;
break;
}
next=pcur->next;
pcur->next=prev;
prev=pcur;
pcur=next;
}

head->next=pcur;
node*tmp=head->next;
while(tmp!=NULL){
cout<data<<“\t”;
tmp=tmp->next;
}
}

  • 1.1.2 已知sqrt(2)约等于1.414,要求不用数学库,求sqrt(2)精确到小数点后10位

  • 1.1.3 给定一个二叉搜索树(BST),找到树中第 K 小的节点

出题人:阿里巴巴出题专家:文景/阿里云 CDN 资深技术专家

参考答案:

  • 考察点

1、基础数据结构的理解和编码能力

2、递归使用

  • 示例

5
/
3 6
/
2 4
/
1

说明:保证输入的 K 满足 1<=K<=(节点数目)

树相关的题目,第一眼就想到递归求解,左右子树分别遍历。联想到二叉搜索树的性质,root 大于左子树,小于右子树,如果左子树的节点数目等于 K-1,那么 root 就是结果,否则如果左子树节点数目小于 K-1,那么结果必然在右子树,否则就在左子树。因此在搜索的时候同时返回节点数目,跟 K 做对比,就能得出结果了。

/**

  • Definition for a binary tree node.
    **/

public class TreeNode {
int val;
TreeNode left;
TreeNode right;
TreeNode(int x) { val = x; }
}

class Solution {
private class ResultType {

boolean found; // 是否找到

int val; // 节点数目
ResultType(boolean found, int val) {
this.found = found;
this.val = val;
}
}

public int kthSmallest(TreeNode root, int k) {
return kthSmallestHelper(root, k).val;
}

private ResultType kthSmallestHelper(TreeNode root, int k) {
if (root == null) {
return new ResultType(false, 0);
}

ResultType left = kthSmallestHelper(root.left, k);

// 左子树找到,直接返回
if (left.found) {
return new ResultType(true, left.val);
}

// 左子树的节点数目 = K-1,结果为 root 的值
if (k - left.val == 1) {
return new ResultType(true, root.val);
}

// 右子树寻找
ResultType right = kthSmallestHelper(root.right, k - left.val - 1);
if (right.found) {
return new ResultType(true, right.val);
}

// 没找到,返回节点总数
return new ResultType(false, left.val + 1 + right.val);
}
}

  • 1.1.4 LRU缓存机制

题目:LRU 缓存机制设计和实现一个 LRU(最近最少使用)缓存数据结构,使它应该支持以下操作:get 和 put。get(key) - 如果 key 存在于缓存中,则获取 key 的 value(总是正数),否则返回 -1。put(key,value) - 如果 key 不存在,请设置或插入 value。当缓存达到其容量时,它应该在插入新项目之前使最近最少使用的项目作废。

  • 1.1.5 关于epoll和select的区别,以下哪些说法是正确的(多选)

A. epoll 和 select 都是 I/O 多路复用的技术,都可以实现同时监听多个 I/O 事件的状态。

B. epoll 相比 select 效率更高,主要是基于其操作系统支持的I/O事件通知机制,而 select 是基于轮询机制。

C. epoll 支持水平触发和边沿触发两种模式。

D. select 能并行支持 I/O 比较小,且无法修改。

出题人:阿里巴巴出题专家:寈峰/阿里技术专家

参考答案:A,B,C

【延伸】那在高并发的访问下,epoll使用那一种触发方式要高效些?当使用边缘触发的时候要注意些什么东西?

  • 1.1.6 从innodb的索引结构分析,为什么索引的 key 长度不能太长
  • 1.1.7 MySQL的数据如何恢复到任意时间点?

华为篇(共计50题)

  • 2.1.0 static有什么用途?(请至少说明两种)
  • 2.1.1 引用与指针有什么区别?
  • 2.1.2 描述实时系统的基本特性
  • ……
    百度篇(共计48题)
  • 3.1.0 在函数内定义一个字符数组,用gets函数输入字符串的时候,如果输入越界,为什么程序会崩溃?
  • 3.1.1 C++中引用与指针的区别
  • 3.1.2 C/C++程序的内存分区
  • ……

腾讯篇(共计82题)

Java基础

  • 4.1.0 JAVA中的几种基本数据类型是什么,各自占用多少字节。
  • 4.1.1 String类能被继承吗,为什么。
  • 4.1.2 String,Stringbuffer,StringBuilder的区别。
  • 4.1.3 ArrayList和LinkedList有什么区别。

JVM

  • 4.4.2 什么情况下会发生栈内存溢出。
  • 4.4.3 JVM的内存结构,Eden和Survivor比例。
  • 4.4.4 JVM内存为什么要分成新生代,老年代,持久代。新生代中为什么要分为Eden和Survivor。

开源框架

  • 4.5.5 简单讲讲tomcat结构,以及其类加载器流程,线程模型等。
  • 4.5.6 tomcat如何调优,涉及哪些参数 。
  • 4.5.7 ……

美团篇(共计40题)

面试结束复盘查漏补缺

每次面试都是检验自己知识与技术实力的一次机会,面试结束后建议大家及时总结复盘,查漏补缺,然后有针对性地进行学习,既能提高下一场面试的成功概率,还能增加自己的技术知识栈储备,可谓是一举两得。

以下最新总结的阿里P6资深Java必考题范围和答案,包含最全MySQL、Redis、Java并发编程等等面试题和答案,用于参考~

重要的事说三遍,关注+关注+关注!

历经30天,说说我的支付宝4面+美团4面+拼多多四面,侥幸全获Offer

image.png

更多笔记分享

历经30天,说说我的支付宝4面+美团4面+拼多多四面,侥幸全获Offer

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录**

需要这份系统化的资料的朋友,可以点击这里获取

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值