美团实习一面

不是搞Java的面试官,可能是管理层,一面主要就是了解一下之前的做的项目,以及算法和编成实现。
出了一道算法题,告诉你道格拉斯算法的过程,
https://blog.youkuaiyun.com/foreverling/article/details/78066632
让你实现这个算法过程,找到所有的特征点。

定义了输入是一系列点、阈值;
输出是所有的特征点,并保证是有前后顺序的。
这个题并没有测试集,主要是实现这个过程给他看

我的代码:
它给的函数定义是c++的,需要自己转化为Java的

import java.util.Scanner;
public class Main {
    public static void main(String[] args) {
        // 输入,arr[Node], tolerance
        int n = arr.length;
        // 先添加首节点
        res.add(arr[0]);
        douglasPeucker(arr, 0, n - 1, tolerance, res);
        // 再添加尾节点
        res.add(arr[n - 1]);
    }
    public static void douglasPeucker(Node[] arr, int left, int right, double tolerance, List<Node> res) {
        double max = 0;
        int c = 0;
        for (int i = left + 1; i < right; i++) {
            double dis = distance_pt_to_segment(arr[i], arr[left], arr[right]);
            if (dis > max) {
                max = dis;
                c = i;
            }
        }
        if (max > tolerance) {
            // 递归左边
            douglasPeucker(arr, left, c, tolerance, res);
            // 添加节点,保证前后顺序
            res.add(arr[c]);
            // 递归右边
            douglasPeucker(arr, c, right, tolerance, res);
        }
    }
    
    public static double distance_pt_to_segment(Node p, Node a1, Node a2){
        return 0; // 不用实现
    }
    
}
class Node {
    double x,
    double y,
}

主要考察的是你对一个为接触过事务(算法)的理解能力,以及用代码将它实现的编程能力

### 美团测试工程师二面经验与面试题 #### 面试流程概述 美团测试开发岗的二面通常会在一面结束后迅速安排,时间间隔可能仅为15分钟[^1]。二面主要考察候选人的技术深度、项目经验和综合能力。以下是一些常见的面试问题和准备建议。 #### 自我介绍 二面通常会以自我介绍开始。候选人需要清晰地阐述自己的背景、技能以及在过往项目中的具体贡献。重点在于突出与测试开发相关的技术和经验。 #### 技术问题 以下是可能涉及的技术问题及准备方向: 1. **Python相关产出** 如果候选人在实习或工作中有Python研发经验,面试官可能会询问具体的产出。例如,是否参与过自动化测试框架的设计、API测试工具的开发等。候选人应准备好详细描述自己在项目中的角色和成果[^1]。 2. **测试用例设计** 面试官可能会要求设计针对某一功能的测试用例。例如,“如何为一个支付功能设计测试用例?”这需要候选人熟悉功能测试、边界值分析和等价类划分等方法[^2]。 3. **性能测试** 了解性能测试的基本概念和工具(如JMeter、Locust)是必要的。面试官可能会问到如何评估系统的吞吐量、响应时间等指标,并提出优化建议[^2]。 4. **代码调试与问题排查** 面试中可能包含实际代码调试题,要求候选人快速定位并解决问题。例如: ```python def find_duplicate(nums): for i in range(len(nums)): if nums[abs(nums[i])] >= 0: nums[abs(nums[i])] = -nums[abs(nums[i])] else: return abs(nums[i]) return -1 ``` 上述代码用于查找数组中的重复元素,但可能存在边界条件问题。候选人需要仔细分析并改进代码逻辑[^2]。 5. **数据库与SQL** 数据库知识也是考察的重点之一。面试官可能会提问关于索引优化、事务处理或复杂查询的问题。例如,“如何优化一条涉及多表联结的SQL语句?”[^2] 6. **分布式系统与微服务** 对于高级测试工程师岗位,分布式系统的设计和测试也是一个重要考点。例如,“如何测试一个高并发环境下的微服务架构?”[^2] #### 综合能力考察 除了技术问题,面试官还可能通过行为面试题评估候选人的沟通能力和团队协作精神。例如,“请分享一次你在项目中解决冲突的经历。” #### 其他注意事项 - 准备过程中,可以参考美团的实际业务场景,结合自身经验进行模拟练习。 - 关注行业动态和技术趋势,展示对新技术的学习热情和应用能力。 ```python # 示例:使用Python实现简单的单元测试 import unittest class TestMathOperations(unittest.TestCase): def test_addition(self): self.assertEqual(1 + 1, 2) if __name__ == '__main__': unittest.main() ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值