华为od社招一面凉经

毕业于985院校,工作9年,1年半 c++,5年移动运营商java,2年海口某500强企业java,想去深圳发展。
一面已挂,面试体验非常差。
6.2 开始说要去深圳,后来说在家视频面试也可以,然后饭也没吃在家等着面试,一直等到10点半,结果第二天才知道我自己理解错了。



6.6号带小孩去棋子湾度假,说是下午面试。然后在酒店一直从下午2点做到6点钟,错过了跟孩子玩水上乐园的机会,8点才去吃饭,被告知,hr弄错了,机考成绩没出来,下周一才能开始面试。
6.8 号通知资格面试,然后又白等了一个晚上,很晚才去吃饭。
6.10 资格面
6.13 约好14:30面试,我提前半个小时在zoom上,然后面试官 14:50才到。
先是做自我介绍 ,介绍近期自己做的项目,然后问项目的访问量,因为是内部项目,访问量确实不是很大。
然后问了自己遇到的问题,我就说了因为数据库没有建立索引导致线上cpu 100%的问题,
然后问在应用上要到的难题,我就介绍了自己项目因为事务处理不当导致的偶然性报错的问题。
然后问了cpu100%的处理方式,我一下子蒙了,然后说了cpu100%的一些可能,死循环,网络等原因。
然后就说top命令查看,定位到具体的进程,然后想说jmap,又不确定内存问题会不会导致cpu升高,把jstack命令忘记了。
然后问了虚拟机的内部组成,还有什么时候触发 GC ,刚刚看了深入理解java虚拟机(周志明版),所以都能答的上来。
又问了线程的几种状态。问了微服务都有哪些部分组成,因为最近做项目刚刚接触微服务,所以组成都能答上来,
但是问注册中心的原理没有回答上来。然后就让做一道算法题,这个是我最生气的。
题目很简单 就是m*n的矩形从左上面到右下面的路径有多少条加上面试官讲题目一共用了不到10分钟,
没有debug,面试官说不用debug了,然后他在那边截图下就可以了。
6.15号hr跟我说挂了,然后先是问我算法题是不是没做,然后又说我做错了。
非常糟糕的面试体验哈。最近又要去忙项目了,吐糟下自己非常珍惜的一次面试机会。

import java.util.Arrays;
import java.util.Scanner;
import java.util.TreeSet;
public class hwjk {
    static  int count = 0;
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        while (sc.hasNext()) {
            int m=sc.nextInt();
            int n=sc.nextInt();
            count=0;
            backTrack(0,0,m-1,n-1);
            System.out.println(count);
        }
        sc.close();
    }
    public  static  void backTrack(int i,int j,int m,int n)
    {
        if(i==m && j==n)
        {
            count++;
        }
        else
        {
            if(i<m)
            {
                backTrack(i+1,j,m,n);
            }
            if(j<n)
            {
                backTrack(i,j+1,m,n);
            }
        }
        return;
    }
}


#华为od##华为##社招##Java工程师##面经#
全部评论
最后一道算法题应该用dp...
3 回复 分享
发布于 2020-06-15 23:05
private static void getByDp(int[][] result, int m, int n) {         //每一行的第一个都只有一种走法         for (int i = 0; i < m; i++) {             result[i][0] = 1;         }         //每一列第一个也只有一个解法         for (int j = 0; j < n; j++) {             result[0][j] = 1;         }         //计算mn按照公式         for (int i = 1; i < m; i++) {             for (int j = 1; j < n; j++) {                 result[i][j]  = result[i-1][j] + result[i][j-1];             }         }     }
2 回复 分享
发布于 2021-04-12 11:10
9年啊!老哥nb
1 回复 分享
发布于 2020-06-17 11:22
9年工作经验是不是要的工资太高了?
点赞 回复 分享
发布于 2020-06-18 21:42
递归也是可以的,只是不要用回溯。回溯的时间复杂度太高。 public static int dfs(int m, int n){     if(n == 0 || m == 0){     return 1; } return dfs(n-1, m) + dfs(n, m-1); } 根据这个递归又可以用相应的动态规划
点赞 回复 分享
发布于 2020-09-21 05:43

相关推荐

12 20 评论
分享
牛客网
牛客企业服务