返回介绍

solution / 2000-2099 / 2010.The Number of Seniors and Juniors to Join the Company II / README

发布于 2024-06-17 01:03:12 字数 3250 浏览 0 评论 0 收藏 0

2010. 职员招聘人数 II

English Version

题目描述

表: Candidates

+-------------+------+
| Column Name | Type |
+-------------+------+
| employee_id | int  |
| experience  | enum |
| salary    | int  |
+-------------+------+
employee_id 是该表中具有唯一值的列。
经验是一个枚举,其中包含一个值(“高级”、“初级”)。
此表的每一行都显示候选人的id、月薪和经验。
每个候选人的工资保证是 唯一 的。

 

一家公司想雇佣新员工。公司的工资预算是 $70000 。公司的招聘标准是:

  1. 继续雇佣薪水最低的高级职员,直到你不能再雇佣更多的高级职员。
  2. 用剩下的预算雇佣薪水最低的初级职员。
  3. 继续以最低的工资雇佣初级职员,直到你不能再雇佣更多的初级职员。

编写一个解决方案,查找根据上述条件雇用职员的 ID。
任意顺序 返回结果表。
返回结果格式如下例所示。

 

示例 1:

输入:
Candidates table:
+-------------+------------+--------+
| employee_id | experience | salary |
+-------------+------------+--------+
| 1       | Junior   | 10000  |
| 9       | Junior   | 15000  |
| 2       | Senior   | 20000  |
| 11      | Senior   | 16000  |
| 13      | Senior   | 50000  |
| 4       | Junior   | 40000  |
+-------------+------------+--------+
输出: 
+-------------+
| employee_id |
+-------------+
| 11      |
| 2       |
| 1       |
| 9       |
+-------------+
解释: 
我们可以雇佣2名具有ID(11,2)的高级员工。由于预算是7万美元,他们的工资总额是3.6万美元,我们还有3.4万美元,但他们不足以雇佣ID为 13 的高级职员。
我们可以雇佣2名ID为(1,9)的初级员工。由于剩余预算为3.4万美元,他们的工资总额为2.5万美元,我们还有9000美元,但他们不足以雇佣ID为 4 的初级员工。

示例 2:

输入:
Candidates table:
+-------------+------------+--------+
| employee_id | experience | salary |
+-------------+------------+--------+
| 1       | Junior   | 25000  |
| 9       | Junior   | 10000  |
| 2       | Senior   | 85000  |
| 11      | Senior   | 80000  |
| 13      | Senior   | 90000  |
| 4       | Junior   | 30000  |
+-------------+------------+--------+
输出: 
+-------------+
| employee_id |
+-------------+
| 9       |
| 1       |
| 4       |
+-------------+
解释: 
我们不能用目前的预算雇佣任何高级员工,因为我们需要至少 80000 美元来雇佣一名高级员工。
我们可以用剩下的预算雇佣三名初级员工。

解法

方法一:窗口函数

相似题目:

# Write your MySQL query statement below
WITH
  s AS (
    SELECT
      employee_id,
      SUM(salary) OVER (ORDER BY salary) AS cur
    FROM Candidates
    WHERE experience = 'Senior'
  ),
  j AS (
    SELECT
      employee_id,
      IFNULL(
        SELECT
          MAX(cur)
        FROM s
        WHERE cur <= 70000,
        0
      ) + SUM(salary) OVER (ORDER BY salary) AS cur
    FROM Candidates
    WHERE experience = 'Junior'
  )
SELECT
  employee_id
FROM s
WHERE cur <= 70000
UNION
SELECT
  employee_id
FROM j
WHERE cur <= 70000;

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文