蚂蚁面试SQL—分层贪心招聘问题

题目描述

某互联网大厂在进行员工招聘,给定固定的薪资预算【12万】,公司制定了如下贪心招聘策略:

  1. 优先招聘 高职级员工(P7>P6>P5)
  2. 在同一职级内,优先招聘期望薪资更低的候选人
  3. 在满足高职级招聘人数尽可能多的前提下,再考虑低职级
  4. 总招聘薪资不能超过预算

数据模拟

sql 复制代码
CREATE TABLE dwd_emp_candidate_di (
    candidate_id VARCHAR(20) COMMENT '候选者ID',
    level VARCHAR(20) COMMENT '应聘职级',
    salary DOUBLE COMMENT '预期薪资(单位:万)'
);

INSERT INTO dwd_emp_candidate_di VALUES
('001', 'P6', 2.5),
('002', 'P6', 2.5),
('003', 'P7', 5.0),
('004', 'P7', 4.5),
('005', 'P7', 4.0),
('006', 'P6', 3.0),
('007', 'P5', 2.0),
('008', 'P5', 1.8);

思路分析

  • 本题本质上是一个 带有优先级约束的贪心选择问题
    • 首先将P7员工按照薪资排序,优先招聘工资较低的员工,确保不会超过预算,计算剩余预算
    • 然后再将P6员工按照薪资排序,优先招聘工资较低的员工,确保不会超过上述剩余预算,计算剩余预算
    • 以此类推

参考答案

sql 复制代码
WITH
p7_ranked AS (
    SELECT
        candidate_id,
        level,
        salary,
        SUM(salary) OVER (ORDER BY salary) AS running_salary,
        row_number() over (ORDER BY salary) AS rk
    FROM dwd_emp_candidate_di
    WHERE level = 'P7'
),
p7_hired AS (
    SELECT *
    FROM p7_ranked
    WHERE running_salary <= 12
),
p7_budget AS (
    SELECT COALESCE(SUM(salary), 0) AS used_budget
    FROM p7_hired
),
p6_ranked AS (
    SELECT
        candidate_id,
        level,
        salary,
        SUM(salary) OVER (ORDER BY salary) AS running_salary
    FROM dwd_emp_candidate_di
    WHERE level = 'P6'
),
p6_hired AS (
    SELECT p6.*
    FROM p6_ranked p6
    JOIN p7_budget b
    ON 1 = 1
    WHERE p6.running_salary <= (12 - b.used_budget)
),
p6_budget AS (
    SELECT COALESCE(SUM(salary), 0) AS used_budget
    FROM p6_hired
),
p5_ranked AS (
    SELECT
        candidate_id,
        level,
        salary,
        SUM(salary) OVER (ORDER BY salary) AS running_salary
    FROM dwd_emp_candidate_di
    WHERE level = 'P5'
),
p5_hired AS (
    SELECT p5.*
    FROM p5_ranked p5
    JOIN p7_budget b7
    ON 1 = 1
    JOIN p6_budget b6
    ON 1 = 1
    WHERE p5.running_salary <= (12 - b7.used_budget - b6.used_budget)
)
SELECT candidate_id, level, salary FROM p7_hired
UNION ALL
SELECT candidate_id, level, salary FROM p6_hired
UNION ALL
SELECT candidate_id, level, salary FROM p5_hired;
相关推荐
阿波罗尼亚3 小时前
数据库序列(Sequence)
数据库
Junsir大斗师3 小时前
Nginx服务器代理Postgresql-16后端数据库
数据库·nginx
Je1lyfish3 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
野生技术架构师4 小时前
2026年最全Java面试题及答案汇总(建议收藏,面试前看这篇就够了)
java·开发语言·面试
Agentic AI人工智能与大数据4 小时前
数据产品运营指南:如何提升用户活跃度?这4个策略让数据产品不再“沉睡”
大数据·ai·产品运营
一只叫煤球的猫5 小时前
ThreadForge 源码解读一:ThreadScope 如何把并发任务放进清晰边界?
java·面试·开源
m0_596749095 小时前
如何防止SQL拼接漏洞_使用PDO对象实现安全的SQL交互
jvm·数据库·python
飞Link5 小时前
开发者必读:2026 欧盟“AI Omnibus”法案达成,技术合规性红线在哪里?
大数据
老纪的技术唠嗑局6 小时前
深度解析 LLM Wiki / Obsidian-Wiki / GBrain:Agent 时代知识的“自组织”与“自进化”
大数据·数据库·人工智能·算法
好赞科技7 小时前
2026年高口碑餐厅预约小程序排行榜:智能就餐新体验一键解锁
大数据·微信小程序