mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-09-12 19:01:47 +08:00
139 lines
4.7 KiB
HTML
139 lines
4.7 KiB
HTML
<p>表:<code>employees</code></p>
|
||
|
||
<pre>
|
||
+-------------+---------+
|
||
| Column Name | Type |
|
||
+-------------+---------+
|
||
| employee_id | int |
|
||
| name | varchar |
|
||
+-------------+---------+
|
||
employee_id 是这张表的唯一主键。
|
||
每一行包含一名员工的信息。
|
||
</pre>
|
||
|
||
<p>表:<code>performance_reviews</code></p>
|
||
|
||
<pre>
|
||
+-------------+------+
|
||
| Column Name | Type |
|
||
+-------------+------+
|
||
| review_id | int |
|
||
| employee_id | int |
|
||
| review_date | date |
|
||
| rating | int |
|
||
+-------------+------+
|
||
review_id 是这张表的唯一主键。
|
||
每一行表示一名员工的绩效评估。评分在 1-5 的范围内,5分代表优秀,1分代表较差。
|
||
</pre>
|
||
|
||
<p>编写一个解决方案,以找到在过去三次评估中持续提高绩效的员工。</p>
|
||
|
||
<ul>
|
||
<li>员工 <strong>至少需要</strong> <code>3</code> <strong>次评估 </strong>才能被考虑</li>
|
||
<li>员工过去的 <code>3</code> 次评估,评分必须 <strong>严格递增</strong>(每次评价都比上一次好)</li>
|
||
<li>根据 <code>review_date</code> 为每位员工分析最近的 <code>3</code> 次评估</li>
|
||
<li><strong>进步分数</strong> 为最后 <code>3</code> 次评估中最后一次评分与最早一次评分之间的差值</li>
|
||
</ul>
|
||
|
||
<p>返回结果表以<em> </em><strong>进步分数 降序</strong> 排序,然后以 <strong>名字</strong> <strong>升序</strong> 排序。</p>
|
||
|
||
<p>结果格式如下所示。</p>
|
||
|
||
<p> </p>
|
||
|
||
<p><strong class="example">示例:</strong></p>
|
||
|
||
<div class="example-block">
|
||
<p><strong>输入:</strong></p>
|
||
|
||
<p>employees 表:</p>
|
||
|
||
<pre class="example-io">
|
||
+-------------+----------------+
|
||
| employee_id | name |
|
||
+-------------+----------------+
|
||
| 1 | Alice Johnson |
|
||
| 2 | Bob Smith |
|
||
| 3 | Carol Davis |
|
||
| 4 | David Wilson |
|
||
| 5 | Emma Brown |
|
||
+-------------+----------------+
|
||
</pre>
|
||
|
||
<p>performance_reviews 表:</p>
|
||
|
||
<pre class="example-io">
|
||
+-----------+-------------+-------------+--------+
|
||
| review_id | employee_id | review_date | rating |
|
||
+-----------+-------------+-------------+--------+
|
||
| 1 | 1 | 2023-01-15 | 2 |
|
||
| 2 | 1 | 2023-04-15 | 3 |
|
||
| 3 | 1 | 2023-07-15 | 4 |
|
||
| 4 | 1 | 2023-10-15 | 5 |
|
||
| 5 | 2 | 2023-02-01 | 3 |
|
||
| 6 | 2 | 2023-05-01 | 2 |
|
||
| 7 | 2 | 2023-08-01 | 4 |
|
||
| 8 | 2 | 2023-11-01 | 5 |
|
||
| 9 | 3 | 2023-03-10 | 1 |
|
||
| 10 | 3 | 2023-06-10 | 2 |
|
||
| 11 | 3 | 2023-09-10 | 3 |
|
||
| 12 | 3 | 2023-12-10 | 4 |
|
||
| 13 | 4 | 2023-01-20 | 4 |
|
||
| 14 | 4 | 2023-04-20 | 4 |
|
||
| 15 | 4 | 2023-07-20 | 4 |
|
||
| 16 | 5 | 2023-02-15 | 3 |
|
||
| 17 | 5 | 2023-05-15 | 2 |
|
||
+-----------+-------------+-------------+--------+
|
||
</pre>
|
||
|
||
<p><strong>输出:</strong></p>
|
||
|
||
<pre class="example-io">
|
||
+-------------+----------------+-------------------+
|
||
| employee_id | name | improvement_score |
|
||
+-------------+----------------+-------------------+
|
||
| 2 | Bob Smith | 3 |
|
||
| 1 | Alice Johnson | 2 |
|
||
| 3 | Carol Davis | 2 |
|
||
+-------------+----------------+-------------------+
|
||
</pre>
|
||
|
||
<p><strong>解释:</strong></p>
|
||
|
||
<ul>
|
||
<li><strong>Alice Johnson (employee_id = 1):</strong>
|
||
|
||
<ul>
|
||
<li>有 4 次评估,分数:2, 3, 4, 5</li>
|
||
<li>最后 3 次评估(按日期):2023-04-15 (3), 2023-07-15 (4), 2023-10-15 (5)</li>
|
||
<li>评分严格递增:3 → 4 → 5</li>
|
||
<li>进步分数:5 - 3 = 2</li>
|
||
</ul>
|
||
</li>
|
||
<li><strong>Carol Davis (employee_id = 3):</strong>
|
||
<ul>
|
||
<li>有 4 次评估,分数:1, 2, 3, 4</li>
|
||
<li>最后 3 次评估(按日期):2023-06-10 (2),2023-09-10 (3),2023-12-10 (4)</li>
|
||
<li>评分严格递增:2 → 3 → 4</li>
|
||
<li>进步分数:4 - 2 = 2</li>
|
||
</ul>
|
||
</li>
|
||
<li><strong>Bob Smith (employee_id = 2):</strong>
|
||
<ul>
|
||
<li>有 4 次评估,分数:3,2,4,5</li>
|
||
<li>最后 3 次评估(按日期):2023-05-01 (2),2023-08-01 (4),2023-11-01 (5)</li>
|
||
<li>评分严格递增:2 → 4 → 5</li>
|
||
<li>进步分数:5 - 2 = 3</li>
|
||
</ul>
|
||
</li>
|
||
<li><strong>未包含的员工:</strong>
|
||
<ul>
|
||
<li>David Wilson (employee_id = 4):之前 3 次评估都是 4 分(没有进步)</li>
|
||
<li>Emma Brown (employee_id = 5):只有 2 次评估(需要至少 3 次)</li>
|
||
</ul>
|
||
</li>
|
||
</ul>
|
||
|
||
<p>输出表以 improvement_score 降序排序,然后以 name 升序排序。</p>
|
||
</div>
|