字节跳动 三次失败的一面后,58天读完这份485页的中高级Java面试题,终获腾讯offer

抖音一面挂

2020/4/1

  • 介绍一下项目
  • java内部类
  • 匿名内部类为什么变量置为fina
  • 多态介绍一下 原理是什么 怎么实现的
  • 设计模式说一下(说了工厂模式、单例、策略) 手写了个懒汉单例、DCL、饿汉。 问简单工厂、工厂、抽象工厂区别
  • K个一组反转链表

字节跳直播中台 头条客户端凉经

2020/2/14

  • 抽象类与接口

  • 垃圾回收(然后我说了四种引用什么时候GC)

  • 什么时候发生内存泄漏、内部类引用外部类泄漏是什么原因

  • hashMap怎么实现,他的get、put是怎么实现的

  • 死锁,怎么避免。

  • synchronized锁是什么锁(我就说了是系统的同步互斥锁)原理应该是monitor(监视器)

  • 你的[项目]中注册登录是怎么实现的

  • http四次挥手

  • http状态码

  • 算法题:leetCode.120 没做出来。。。

    `class` `Solution {`
    
    `public` `int` `minimumTotal(List<List<Integer>> triangle) {`
    
    `if``(triangle ==` `null` `|| triangle.size() ==` `0``){`
    
    `return` `0``;`
    
    `}`
    
    `//二维数组dp[][]`
    
    `// int[][] dp = new int[triangle.size()+1][triangle.size()+1];`
    
    `// for(int i = triangle.size()-1; i>=0; i--){`
    
    `//     List<Integer> curTri = triangle.get(i);`
    
    `//     for(int j = 0; j<curTri.size(); j++){`
    
    `//         dp[i][j] = Math.min(dp[i+1][j], dp[i+1][j+1]) + curTri.get(j);`
    
    `//     }`
    
    `// }`
    
    `// // 只需要记录每一层的最小值即可`
    
    `// int[] dp = new int[triangle.size()+1];`
    
    `// for(int i = triangle.size()-1; i>=0; i++){`
    
    `//     List<Integer> curTri = triangle.get(i);`
    
    `//     for(int j  = 0; j<curTri.size(); j++){`
    
    `//         //这里的dp[j] 使用的时候默认是上一层的,赋值之后变成当前层`
    
    `//         dp[j] = Math.min(dp[j], dp[j+1]) + curTri.get(j);`
    
    `//     }`
    
    `// }`
    
    `// return dp[0][0];`
    
    `//标准On`
    
    `int` `n = triangle.size();`
    
    `int``[] dp =` `new` `int``[n];`
    
    `for``(``int` `i =` `0``; i < n; i++)`
    
    `dp[i] = triangle.get(n -` `1``).get(i);`
    
    `for``(``int` `i = n -` `2``; i >=` `0``; i--) {`
    
    `for``(``int` `j =` `0``; j <= i; j ++) {`
    
    `dp[j] = Math.min(dp[j], dp[j+``1``]) + triangle.get(i).get(j);`
    
    `}`
    
    `}   `
    
    `return` `dp[``0``];`
    
    `//递归法`
    
    `//return minimumTotalHelper(triangle, 0, 0, new int[triangle.size()][triangle.size()]);`
    
    `}`
    
    `int` `minimumTotalHelper(List<List<Integer>> triangle,` `int` `row,` `int` `col,` `int``[][] memo){`
    
    `if``(memo[row][col] !=` `0``)` `return` `memo[row][col];`
    
    `if``(row == triangle.size()-``1``){`
    
    `return` `memo[row][col] = triangle.get(row).get(col);`
    
    `}`
    
    `int` `left = minimumTotalHelper(triangle, row+``1``, col, memo);`
    
    `int` `right = minimumTotalHelper(triangle, row+``1``, col+``1``, memo);`
    
    `return` `memo[row][col] = Math.min(left,right) + triangle.get(row).get(col);`
    
    `}`
    
    `}`
    
     |
    

字节跳动 头条客户端凉经

2020/1/19

  • 自我介绍

    算法题

  • Q:找出一个数组的长度Top k的升序子数组,并按长度降序输出。

  • 输入:[2,1,4,5,8,3,7,10,2,5] k=2

  • 输出:[1,4,5,8],[3,7,10]

  • 思路:刚开始和面试官聊思路,我以为是找出升序子数组然后把他们里面的元素降序输出,做完后才发现理解错题意了。题目的意思就是找出升序子数组,按照子数组的长度降序输出子数组。。。

`public` `class` `Main {`

`public` `void` `reverse(``int``[] array,` `int` `k){`

`//找升序子数组`

`int``[] pivot =` `new` `int``[k];``//存第i个子数组的开始坐标`

`int``[] end =` `new` `int``[k];``//存第i个子数组的结束坐标`

`int` `j =` `0``;`

`int` `pivot_temp =` `0``;`

`int` `end_temp =` `0``;`

`for``(``int` `i=``0``; i<array.length;){`

`if``((i != array.length-``1``) && (array[i] > array[i+``1``])){`

`if``(end_temp > pivot_temp){`

`pivot[j] = pivot_temp;`

`end[j] = end_temp;`

`j++;`

`}`

`i++;`

`pivot_temp = i;`

`end_temp = pivot_temp;`

`}``else``{`

`i++;`

`end_temp++;`

`}`

`}`

`/*`

`按照子数组长度降序`

`*/`

`int``[] len =` `new` `int``[k];`

`int``[] index =` `new` `int``[k];``//存储降序顺序  index 与len 一一对应`

`for``(``int` `i=``0``; i<k; i++){`

`len[i] = end[i] - pivot[i] +``1``;`

`index[i] = i;`

`}`

`for``(``int` `i=``0``; i<k; i++){``//选择排序   //index[i]  是存Top i长度max的数组的索引`

`for``(``int` `w=i; w<k; w++){`

`if``(len[w] > len[i]){`

`int` `temp = len[w];`

`len[w] = len[i];`

`len[i] = temp;`

`int` `index_temp = index[w];`

`index[w] = index[i];`

`index[i] = index_temp;`

`}`

`}`

`}`

`//输出`

`for``(``int` `i=``0``; i<k; i++){`

`System.out.print(``"["``);`

`for``(``int` `w=pivot[index[i]]; w=end[i]; w--    没把``for``循环条件改回来导致输出为空,只说了思路开始问java基础。好亏啊这种窒息操作`

`if``(w == end[index[i]]){`

`System.out.print(array[w]);`

`}``else``{`

`System.out.print(array[w] +` `","``);`

`}`

`}`

`if``(i == k-``1``){`

`System.out.print(``"]"``);`

`}``else``{`

`System.out.print(``"],"``);`

`}`

`}`

`}`

`public` `static` `void` `main(String[] args) {`

`int``[] test =` `new` `int``[]{``2``,``1``,``4``,``5``,``8``,``3``,``7``,``10``,``2``,``5``};`

`Main main =` `new` `Main();`

`main.reverse(test,``2``);`

  • Java基础

    • 说一说Java内存模型、JVM内存模型* HashMap怎么实现的* 线程 wait()和sleep()区别* 线程安全怎么实现* 说一说垃圾回收算法

    Android基础(估计是看我有Android基础才问的。0基础不会问,我看其他0基础的问的大都是计网和java基础!啊!没复习啊!)

  • Android页面绘制流程

  • Handler在子线程怎么使用

  • 就完了......
    资料库分享:


点此进入资料免费获取通道。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,185评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,445评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,684评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,564评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,681评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,874评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,025评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,761评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,217评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,545评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,694评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,351评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,988评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,778评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,007评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,427评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,580评论 2 349

推荐阅读更多精彩内容