飞书社招技术一面 | 飞书面经

时间

2024.05.23

问题

  1. 个人介绍
  2. 疯狂问项目(过往项目都问了一遍,大概20分钟)
  3. 感觉这块答得不够好,基本就是实话实说了,得提前润色一下才行
  4. redis、mq、mysql的一些设计或者底层实现了解吗?
  5. 问的很宽泛、重点说了mysql的b+树索引设计
  6. mysql索引的设计,会考虑哪些因素?
  7. 字段数据区分度较大
  8. left join 和 where 查询较频繁的字段
  9. 要考虑索引覆盖,避免回表查询(来自面试官善意的提醒)
  10. redis底层数据结构实现了解吗?
  11. 类比java,具体不是很清楚(被问过很多次了,需要好好复习下)
  12. 用过RPC吗?
  13. 算法:N数之和

题目描述

不重复的随机数数组[1,3,8,11,13,22,34,61,88,772],总共有10个数字。

取任意数字,不可重复取数据,求它们的和,判断结果能否等于n。

输入为数组arr,目标和n。

输出true/false

题解:

public static void main(String[] args) {
        int[] arr = new int[]{1,8,10,11,13,22,34,61,88,772};
        System.out.println(combinationSum(arr, 17));
    }

    /**
     回溯 + 剪枝
     */
    public static boolean combinationSum(int[] candidates, int target) {
        //排除不合理数组
        if(candidates.length == 0) {
            return false;
        }
        return backtrack(candidates, 0, target, 0);
    }

    static boolean backtrack(int[] candidates, int start, int target, int sum) {

        if(sum == target) {
            // 找到目标和
            return true;
        }
        if (sum > target) {
            // 超过目标和,直接结束
            return false;
        }
        boolean res = false;
        for(int i = start; i < candidates.length; i++) {
            // 做选择
            sum += candidates[i];
            // 进入下一层决策树
            res = backtrack(candidates, i + 1, target, sum);
            // 取消选择
            sum -= candidates[i];
            if (res) break;
        }
        return res;
    }

参考lc:39组合总和,不过做了简化,只要符合就返回ture,否则false

个人总结

  1. 自我介绍需要提前准备一份
  2. 项目经历需要整理文字叙述
  3. 八股需要复习,熟练后深入理解
#字节面经##面经##社招面经##社招#
全部评论

相关推荐

2024-12-27 23:45
已编辑
三江学院 Java
程序员牛肉:死局。学历+无实习+项目比较简单一点。基本就代表失业了。 尤其是项目,功能点实在是太假了。而且提问点也很少。第一个项目中的使用jwt和threadlocal也可以作为亮点写出来嘛?第二个项目中的“后端使用restful风格”,“前端采用vue.JS”,“使用redis”也可以作为亮点嘛? 项目实在是太简单了,基本就是1+1=2的水平。而你目标投递的肯定也是小厂,可小厂哪里有什么培养制度,由于成本的问题,人家更希望你来能直接干活,所以你投小厂也很难投。基本就是死局,也不一定非要走后端这条路。可以再学一学后端之后走测试或者前端。 除此之外,不要相信任何付费改简历的。你这份简历没有改的必要了,先沉淀沉淀
点赞 评论 收藏
分享
评论
12
13
分享

创作者周榜

更多
牛客网
牛客企业服务