小红书一面、二面、HR面、offer

一面

一面面试官主要询问了简历上的内容,比较有趣的两个题是这个

  1. bagging和boosting在参数选择上有什么不同:

    • Bagging方法不需要特别关注参数选择,因为它使用随机采样自所有训练样本中进行有放回地重复采样,构建多个基学习器。每个基学习器都是独立的,并行地进行训练。因此,每个基学习器使用的参数都是原始数据集上的默认参数或经验选择的参数。
    • Boosting方法对参数的选择相对较为重要,因为它是通过逐步优化基学习器来提升整体性能的。训练过程中,每个基学习器的训练都会受到前一个基学习器的影响。通常,Boosting方法会选择一些关键参数,如学习率(learning rate)、树的深度(tree depth)、迭代次数等。这些参数可以根据数据集和任务的特点进行调整,以获得更好的性能。
  2. 编程题:计算n的阶乘结果有多少个零:

    #include <iostream>
    
    // 计算 n 的阶乘结果中有多少个零
    int countTrailingZeros(int n) {
        int count = 0;
    
        // 计算因子中 5 的个数
        for (int i = 5; n / i >= 1; i *= 5) {
            count += n / i;
        }
    
        return count;
    }
    
    int main() {
        int n;
        std::cout << "请输入一个整数 n:";
        std::cin >> n;
    
        int zeros = countTrailingZeros(n);
        std::cout << n << " 的阶乘结果中有 " << zeros << " 个零。" << std::endl;
    
        return 0;
    }
    

二面

二面面试官看了简历觉得和面试岗位匹配度不够高,所以没怎么问简历上的内容,写了三道题。

  1. 编程题:实现数组最长的递增子序列

    解法1:动态规划,时间复杂度

    #include <iostream>
    #include <vector>
    #include <algorithm>
    
    int LongestIncreasingSubsequence(const std::vector<int>& nums) {
        int n = nums.size();
        std::vector<int> dp(n, 1);
    
        for (int i = 1; i < n; i++) {
            for (int j = 0; j < i; j++) {
                if (nums[i] > nums[j]) {
                    dp[i] = std::max(dp[i], dp[j] + 1);
                }
            }
        }
    
        return *std::max_element(dp.begin(), dp.end());
    }
    
    int main() {
        std::vector<int> nums = {10, 9, 2, 5, 3, 7, 101, 18};
        int longest = LongestIncreasingSubsequence(nums);
      
        std::cout << "数组的最长递增子序列长度为: " << longest << std::endl;
    
        return 0;
    }
    

    解法2:二分法+动态规划 时间复杂度为

    #include <iostream>
    #include <vector>
    #include <algorithm>
    
    int LongestIncreasingSubsequence(const std::vector<int>& nums) {
        int n = nums.size();
        std::vector<int> dp(n, 0);
        int length = 0;
    
        for (int i = 0; i < n; i++) {
            int left = 0, right = length;
            while (left < right) {
                int mid = left + (right - left) / 2;
                if (dp[mid] < nums[i]) {
                    left = mid + 1;
                } else {
                    right = mid;
                }
            }
            dp[left] = nums[i];
            if (left == length) {
                length++;
            }
        }
    
        return length;
    }
    
    int main() {
        std::vector<int> nums = {10, 9, 2, 5, 3, 7, 101, 18};
        int longest = LongestIncreasingSubsequence(nums);
    
        std::cout << "数组的最长递增子序列长度为: " << longest << std::endl;
    
        return 0;
    }
    

第一种解法不难,直接就写出来了,但是面试官说要更优的时间复杂度,那也就只剩下那个打扑克牌的排序方法,还是需要背一下的。

  1. 编程题:滑动窗口最大值

    #include <iostream>
    #include <vector>
    #include <deque>
    
    std::vector<int> slidingWindowMax(const std::vector<int>& nums, int k) {
        std::vector<int> result;
        std::deque<int> window;
    
        for (int i = 0; i < nums.size(); i++) {
            // 移除窗口外的元素
            if (!window.empty() && window.front() == i - k)
                window.pop_front();
    
            // 保持窗口内元素降序排列
            while (!window.empty() && nums[i] > nums[window.back()])
                window.pop_back();
    
            // 将当前元素索引加入窗口
            window.push_back(i);
    
            // 当窗口完全覆盖k个元素时,将窗口内的最大值加入结果
            if (i >= k - 1)
                result.push_back(nums[window.front()]);
        }
    
        return result;
    }
    
    int main() {
        std::vector<int> nums = {1, 3, -1, -3, 5, 3, 6, 7};
        int k = 3;
    
        std::vector<int> result = slidingWindowMax(nums, k);
    
        std::cout << "滑动窗口最大值:" << std::endl;
        for (int val : result) {
            std::cout << val << " ";
        }
        std::cout << std::endl;
    
        return 0;
    }
    

​ 这个题一开始没有理解面试官想要我写什么,给我举得例子是CNN里面的MaxPooling操作,不过要我实现一维的。沟通了半天才发 现就是滑动窗口最大值的题,双端队列解决了。然后又问最大堆或者最小堆能不能解决,怎么构建最大堆,时间复杂度怎么计算之类 的问题了。

HR面

HR面没有太多困难,都是一些固定的题目,其中问了一道比较印象深刻的题目

  1. 经历了前两面,从面试官那里学到了什么或者说觉得小红书的面试官和其他的面试官的面试有什么特点? 回答:在二面的时候,和小红书面试官交流了比较多的算法内容,小红书面试的算法题还是比较有难度和深度的,考察了的题目也不少,可以看出小红书对基本功的掌握还是比较重视的,幸亏自己全都写出来了。

Offer

alt

总结

整体而言,小红书的面试体验不算好的,但是整体面试难度不大,还是比较轻松就能拿到的。

#晒一晒我的offer##小红书##offer#
全部评论
楼主什么部门啊,以及timeline是咋样的
1 回复 分享
发布于 2023-09-18 11:03 北京
大佬,小红书HR面问技术吗?
点赞 回复 分享
发布于 2024-04-24 09:27 湖北

相关推荐

2024-12-12 16:52
中山大学 Java
面试总共分为&nbsp;。一面为技术面&nbsp;,侧重于八股基础&nbsp;;二面为技术面&nbsp;,侧重于项目细节和场景题考验&nbsp;;三面为技术面&nbsp;,侧重于八股基础&nbsp;;四面为HR面&nbsp;。一面:面试内容:1.垃圾回收器,cms2.垃圾回收机制3.Redis,单线程模型结构,阻塞,Zset,哨兵模式,大&nbsp;Key&nbsp;问题会影响内存性能吗4.MQ&nbsp;使用场景5.Spring&nbsp;循环依赖,有没有遇到过,怎么定位,怎么解决6.Maven&nbsp;传递依赖,有什么具体的问题7.Spring&nbsp;MVC手撕代码:反转链表面试体验:一面对项目不做深挖,主要考查八股,除了以上问题以外数据库问的也多,但都是比较常见的点,如mvcc、索引、事务等问题。二面:面试内容:1.项目难点2.拦截器用的是Spring还是Servlet3.SpringAOP拦截器什么情况下会失效4.JDK和CGLIB区别5.ThreadLocal具体什么情况下取加密字段6.如果字段被拦截了怎么办,怎么保证安全性,网关层面做了加密,那如果让你来加密,你会怎么做7.场景图:如果要设计一个定时器,用什么数据结构8.算法:字符串转Integer,遇到超出范围的数据怎么办,数据越界怎么办 面试体验:压力最大的一面,对应的面试官所在的组应该就是最终的组。二面基本不问寻常八股,都是从项目的角度延伸开来问问题,我的项目的亮点是拦截器方案的改进,所以就针对这部分做深入挖掘。场景题没有标准答案,答数组、堆等都可以,但会针对这种数据结构里面的缺陷和某种场景反问,让你一步一步打补丁修正答案,最后提出了时间轮的数据结构概念。三面:面试内容:1.&nbsp;Transactional注解什么时候会失效?基于原理2.&nbsp;binlog&nbsp;什么用途3.&nbsp;jvm,分为哪几个区域,哪个区域会发生内存溢出4.&nbsp;hashmap&nbsp;源码看过吗,扩容原理,扩容过程5.&nbsp;什么情况下,走不到索引上6.&nbsp;怎么定位线程死锁,怎么解决7.&nbsp;线程池,常见参数,工作队列的大小怎么定,线程数怎么定面试体验:三面像交叉面,没有深入问之前的问题,还是以检验基础八股为主,时间较短,没有手撕。四面:面试内容:1.&nbsp;自我介绍2.&nbsp;职业规划3.&nbsp;为什么偏向于选择支付方向4.&nbsp;&nbsp;目前手头有哪些offer,签约了吗面试体验:常规HR面,没有开摄像头。
查看26道真题和解析
点赞 评论 收藏
分享
评论
3
16
分享

创作者周榜

更多
牛客网
牛客企业服务