7.24 华为提前批Java视频一面

全程一小时,非常准时,面试官也挺nice,就是我比较菜

  1. 聊项目相关,主要是 Kafka Connect 的一些知识
  2. Kafka 可靠性:zookeeper,分布式集群,partition 的 leader 和 follower
  3. 多进程之间的通信方式:管道、共享存储器、消息传递系统(翻了一下操作系统,发现 C/S 模式没答上来)
  4. Java 内存模型,说了一下作用还有主内存+工作内存,还有内存间相互操作的一些命令、约束
  5. Spring 微服务?(我简历里有提到 Spring,但是没有提到微服务,后面得知是部门业务相关所以问了)
  6. OpenStack 了解吗?(同上)
  7. 聊了一下7.15笔试的最后一题(完全背包)
  8. 手撕算法(详情见后文)
  9. volatile 能用来实现免锁队列吗?(我答的是不能保证原子性所以不能)
  10. 如何实现免锁队列?(答了CAS,队列元素用原子类包装)
    1. 面试官一直在问我免锁队列的关键指令是什么?我说了"CompareAndSet"才让他满意

反问环节:

  1. 我还有机会吗?—— 你们提前批都有
  2. 编码风格和习惯?—— 挺好的(主要是手撕算法结束之后,他特意提到编码风格,我就问了一下)
  3. 知识储备需要补充哪些内容?(扯到部门的业务上面去了……和我讲了讲 openstack)

手撕代码:

对字符串列表中的每个字符串进行压缩,输出一个压缩后的字符串列表,要求和原列表的位置相对应

  • 压缩:保留头尾字符,中间用省略掉的字符个数填充,例如 kubernetes 压缩为 k8s
  • 如果出现两个字符串的压缩结果相同,需要从左开始,减少省略的字符,直到压缩结果不同
    • aabbcc & abbbcc => a4c, 改成 aa3c, ab3c
  • 若压缩后的字符串长度没有比原来的短,就输出原先的字符串
  • 提供一个辅助方法,它可以生成从字符串指定位置开始压缩得到的结果
public List<String> wordsCompress(List<String> data);

private String compressHelper(String word, int start){
    // compressHelper("internet", 1) -> "i6t"
    // compressHelper("internet", 2) -> "in5t"
    // compressHelper("internet", 3) -> "int4t"
}

// sample case
// input
{"like", "god", "me", "internet", "internal", "interval", "intension", "face", "intrusion"}

// output
{"l2e", "god", "me", "i6t", "internal", "interval", "inte4n", "f2e", "intr4n"}

说实话自己挺菜的,一开始想了个漏洞百出的错误思路,后来经过面试官提示才写出正确思路:

  • 先预处理列表,把长度相同的字符串组织成一个列表,然后按长度存哈希表
  • 再对每一个长度的哈希桶进行遍历,辅助函数的第二个参数从1递增,直到这个桶生成的不同的压缩结果数和桶内原列表的字符串数相等
  • 整体的所有压缩结果用一个原字符串到压缩结果的字符串的哈希表存一下,方便生成结果
#面经##Java##秋招##校招#
全部评论
lz 哪个部门的提前批啊?
1 回复 分享
发布于 2020-07-24 19:34
华为有提前批?+1
点赞 回复 分享
发布于 2020-07-24 20:09
华为有提前批?
点赞 回复 分享
发布于 2020-07-24 20:06
老哥,如果提前批没过还可以秋招投吗
点赞 回复 分享
发布于 2020-07-24 19:22

相关推荐

02-14 07:38
已编辑
门头沟学院 Java
2.4&nbsp;一面2.6&nbsp;二面2.9&nbsp;三面(hr面)2.13&nbsp;oc1.15号收到面试电话那会就开始准备,因为一开始没底所以选择推迟一段时间面试,之后开始准备八股,准备实习可能会问的东西,这期间hot100过了有六七遍,真的是做吐了快,八股也是背了忘,忘了背,面经也看了很多,虽然最后用上的只有几道题,可是谁知道会问什么呢自从大二上开始学java以来,一路走来真的太痛了,一开始做外卖,点评,学微服务,大二下五六月时,开始投简历,哎,投了一千份了无音讯,开始怀疑自己(虽然能力确实很一般),后来去到一家小小厂,但是并不能学到什么东西,而且很多东西都很不规范,没待多久便离开,大二暑假基本上摆烂很怀疑自己,大三上因为某些原因开始继续学,期间也受到一俩个中小厂的offer,不过学校不知道为啥又不允许中小厂实习只允许大厂加上待遇不太好所以也没去,感觉自己后端能力很一般,于是便打算转战测开,学习了一些比较简单的测试理论(没有很深入的学),然后十二月又开始继续投,java和测开都投,不过好像并没有几个面试,有点打击不过并没有放弃心里还是想争一口气,一月初因为学校事比较多加上考试便有几天没有继续投,10号放假后便继续,想着放假应该很多人辞职可能机会大一点,直到接到字节的面试,心里挺激动的,总算有大厂面试了,虽然很开心,但同时压力也很大,心里真的很想很想很想进,一面前几天晚上都睡不好觉,基本上都是二三点睡六七点醒了,好在幸运终于眷顾我一次了(可能是之前太痛了),一面三十几分钟结束,问的都不太难,而且面试官人挺好但是有些问题问的很刁钻问到了测试的一些思想并不是理论,我不太了解这方面,但是也会给我讲一讲他的理解,但是面完很伤心觉得自己要挂了。但是幸运的是一面过了(感谢面试官),两天后二面,问的同样不算难,手撕也比较简单,但也有一两个没答出来,面试官人很好并没有追问,因为是周五进行的二面,没有立即出结果,等到周一才通知到过了,很煎熬的两天,根本睡不好,好在下周一终于通知二面过了(感谢面试官),然后约第二天三面,听别的字节同学说hr面基本上是谈薪资了,但是我的并不是,hr还问了业务相关的问题,不过问的比较浅,hr还问我好像比较紧张,而且hr明确说了还要比较一下,我说我有几家的面试都拒了就在等字节的面试(当然紧张,紧张到爆了要),三面完后就开始等结果,这几天干啥都没什么劲,等的好煎熬,终于13号下午接到了电话通知oc了,正式邮件也同时发了,接到以后真的不敢信,很激动但更重要的是可以松一口气了,可以安心的休息一下了终于可以带着个好消息过年了,找实习也可以稍微告一段落了,虽然本人很菜,但是感谢字节收留,成为忠诚的节孝子了因为问的比较简单,面经就挑几个记得的写一下一面:1.实习项目的难点说一下2.针对抖音评论设计一下测试用例3.手撕:合并两个有序数组二面:1.为什么转测开2.线程进程区别,什么场景适合用哪个3.发送一个朋友圈,从发出到别人看到,从数据流转的角度说一下会经历哪些过程4.针对抖音刷到广告视频设计测试用例5.手撕:无重复字符的最长字串
牛客85811352...:测开问这么简单?
查看8道真题和解析
点赞 评论 收藏
分享
02-04 15:03
南昌大学 Java
想去三亚看海的迪恩在...:刚刚打电话了说不录取,收了学信网和身份证,入职的信息条都发给我了,这种不录取究竟何意味?
点赞 评论 收藏
分享
评论
2
19
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务