mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-10-24 06:18:57 +08:00
139 lines
6.3 KiB
HTML
139 lines
6.3 KiB
HTML
<p>Table: <code>students</code></p>
|
|
|
|
<pre>
|
|
+--------------+---------+
|
|
| Column Name | Type |
|
|
+--------------+---------+
|
|
| student_id | int |
|
|
| student_name | varchar |
|
|
| major | varchar |
|
|
+--------------+---------+
|
|
student_id is the unique identifier for this table.
|
|
Each row contains information about a student and their academic major.
|
|
</pre>
|
|
|
|
<p>Table: <code>study_sessions</code></p>
|
|
|
|
<pre>
|
|
+---------------+---------+
|
|
| Column Name | Type |
|
|
+---------------+---------+
|
|
| session_id | int |
|
|
| student_id | int |
|
|
| subject | varchar |
|
|
| session_date | date |
|
|
| hours_studied | decimal |
|
|
+---------------+---------+
|
|
session_id is the unique identifier for this table.
|
|
Each row represents a study session by a student for a specific subject.
|
|
</pre>
|
|
|
|
<p>Write a solution to find students who follow the <strong>Study Spiral Pattern</strong> - students who consistently study multiple subjects in a rotating cycle.</p>
|
|
|
|
<ul>
|
|
<li>A Study Spiral Pattern means a student studies at least <code>3</code><strong> different subjects</strong> in a repeating sequence</li>
|
|
<li>The pattern must repeat for <strong>at least </strong><code>2</code><strong> complete cycles</strong> (minimum <code>6</code> study sessions)</li>
|
|
<li>Sessions must be <strong>consecutive dates</strong> with no gaps longer than <code>2</code> days between sessions</li>
|
|
<li>Calculate the <strong>cycle length</strong> (number of different subjects in the pattern)</li>
|
|
<li>Calculate the <strong>total study hours</strong> across all sessions in the pattern</li>
|
|
<li>Only include students with cycle length of <strong>at least </strong><code>3</code><strong> subjects</strong></li>
|
|
</ul>
|
|
|
|
<p>Return <em>the result table ordered by cycle length in <strong>descending</strong> order, then by total study hours in <strong>descending</strong> order</em>.</p>
|
|
|
|
<p>The result format is in the following example.</p>
|
|
|
|
<p> </p>
|
|
<p><strong class="example">Example:</strong></p>
|
|
|
|
<div class="example-block">
|
|
<p><strong>Input:</strong></p>
|
|
|
|
<p>students table:</p>
|
|
|
|
<pre class="example-io">
|
|
+------------+--------------+------------------+
|
|
| student_id | student_name | major |
|
|
+------------+--------------+------------------+
|
|
| 1 | Alice Chen | Computer Science |
|
|
| 2 | Bob Johnson | Mathematics |
|
|
| 3 | Carol Davis | Physics |
|
|
| 4 | David Wilson | Chemistry |
|
|
| 5 | Emma Brown | Biology |
|
|
+------------+--------------+------------------+
|
|
</pre>
|
|
|
|
<p>study_sessions table:</p>
|
|
|
|
<pre class="example-io">
|
|
+------------+------------+------------+--------------+---------------+
|
|
| session_id | student_id | subject | session_date | hours_studied |
|
|
+------------+------------+------------+--------------+---------------+
|
|
| 1 | 1 | Math | 2023-10-01 | 2.5 |
|
|
| 2 | 1 | Physics | 2023-10-02 | 3.0 |
|
|
| 3 | 1 | Chemistry | 2023-10-03 | 2.0 |
|
|
| 4 | 1 | Math | 2023-10-04 | 2.5 |
|
|
| 5 | 1 | Physics | 2023-10-05 | 3.0 |
|
|
| 6 | 1 | Chemistry | 2023-10-06 | 2.0 |
|
|
| 7 | 2 | Algebra | 2023-10-01 | 4.0 |
|
|
| 8 | 2 | Calculus | 2023-10-02 | 3.5 |
|
|
| 9 | 2 | Statistics | 2023-10-03 | 2.5 |
|
|
| 10 | 2 | Geometry | 2023-10-04 | 3.0 |
|
|
| 11 | 2 | Algebra | 2023-10-05 | 4.0 |
|
|
| 12 | 2 | Calculus | 2023-10-06 | 3.5 |
|
|
| 13 | 2 | Statistics | 2023-10-07 | 2.5 |
|
|
| 14 | 2 | Geometry | 2023-10-08 | 3.0 |
|
|
| 15 | 3 | Biology | 2023-10-01 | 2.0 |
|
|
| 16 | 3 | Chemistry | 2023-10-02 | 2.5 |
|
|
| 17 | 3 | Biology | 2023-10-03 | 2.0 |
|
|
| 18 | 3 | Chemistry | 2023-10-04 | 2.5 |
|
|
| 19 | 4 | Organic | 2023-10-01 | 3.0 |
|
|
| 20 | 4 | Physical | 2023-10-05 | 2.5 |
|
|
+------------+------------+------------+--------------+---------------+
|
|
</pre>
|
|
|
|
<p><strong>Output:</strong></p>
|
|
|
|
<pre class="example-io">
|
|
+------------+--------------+------------------+--------------+-------------------+
|
|
| student_id | student_name | major | cycle_length | total_study_hours |
|
|
+------------+--------------+------------------+--------------+-------------------+
|
|
| 2 | Bob Johnson | Mathematics | 4 | 26.0 |
|
|
| 1 | Alice Chen | Computer Science | 3 | 15.0 |
|
|
+------------+--------------+------------------+--------------+-------------------+
|
|
</pre>
|
|
|
|
<p><strong>Explanation:</strong></p>
|
|
|
|
<ul>
|
|
<li><strong>Alice Chen (student_id = 1):</strong>
|
|
|
|
<ul>
|
|
<li>Study sequence: Math → Physics → Chemistry → Math → Physics → Chemistry</li>
|
|
<li>Pattern: 3 subjects (Math, Physics, Chemistry) repeating for 2 complete cycles</li>
|
|
<li>Consecutive dates: Oct 1-6 with no gaps > 2 days</li>
|
|
<li>Cycle length: 3 subjects</li>
|
|
<li>Total hours: 2.5 + 3.0 + 2.0 + 2.5 + 3.0 + 2.0 = 15.0 hours</li>
|
|
</ul>
|
|
</li>
|
|
<li><strong>Bob Johnson (student_id = 2):</strong>
|
|
<ul>
|
|
<li>Study sequence: Algebra → Calculus → Statistics → Geometry → Algebra → Calculus → Statistics → Geometry</li>
|
|
<li>Pattern: 4 subjects (Algebra, Calculus, Statistics, Geometry) repeating for 2 complete cycles</li>
|
|
<li>Consecutive dates: Oct 1-8 with no gaps > 2 days</li>
|
|
<li>Cycle length: 4 subjects</li>
|
|
<li>Total hours: 4.0 + 3.5 + 2.5 + 3.0 + 4.0 + 3.5 + 2.5 + 3.0 = 26.0 hours</li>
|
|
</ul>
|
|
</li>
|
|
<li><strong>Students not included:</strong>
|
|
<ul>
|
|
<li>Carol Davis (student_id = 3): Only 2 subjects (Biology, Chemistry) - doesn't meet minimum 3 subjects requirement</li>
|
|
<li>David Wilson (student_id = 4): Only 2 study sessions with a 4-day gap - doesn't meet consecutive dates requirement</li>
|
|
<li>Emma Brown (student_id = 5): No study sessions recorded</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
|
|
<p>The result table is ordered by cycle_length in descending order, then by total_study_hours in descending order.</p>
|
|
</div>
|