안녕하세요, HELLO
오늘은 Leetcode 알고리즘 문제 '182. Duplicate Emails'에 대해서 살펴보고자 합니다.
알고리즘 문제, 코드, 해설 그리고 Leetcode에서 제공해준 solution 순서대로 정리하였습니다.
STEP 1. 'Duplicate Emails' 알고리즘 문제
STEP 2. 'Duplicate Emails' 코드(code)
STEP 3. 'Duplicate Emails' 해설
STEP 4. 'Duplicate Emails' solution
STEP 1. 'Duplicate Emails' 알고리즘 문제
Write an SQL query to report all the duplicate emails.
Return the result table in any order.
모든 중복 email을 반환하는 SQL query를 작성하면 됩니다.
이때, 결과 테이블은 순서에 상관없습니다.
The query result format is in the following example.
STEP 2. 'Duplicate Emails' 코드(code)
■ Runtime: 377 ms, faster than 68.40% of MySQL online submissions for Duplicate Emails.
■ Memory Usage: 0B, less than 100.00% of MySQL online submissions for Duplicate Emails.
# Write your MySQL query statement below
SELECT email
FROM Person
GROUP BY Person.email
HAVING COUNT(*) >=2;
STEP 3. 'Duplicate Emails' 해설
Person 테이블에서 해당하는 조건인 email을 group by를 통해 중복된 경우(2개 이상)에 email을 반환하는 방식으로, query를 작성했습니다.
STEP 4. 'Duplicate Emails' solution
추가적으로, Leetcode에서 제공해준 solution 코드를 살펴보겠습니다.
이번에는 cross join을 통해서 테이블을 연결해서 email이 동일한 경우와 id가 다른 경우에 email을 반환합니다.
■ Runtime: 421 ms, faster than 54.47% of MySQL online submissions for Duplicate Emails.
■ Memory Usage: 0B, less than 100.00% of MySQL online submissions for Duplicate Emails.
# Write your MySQL query statement below
SELECT DISTINCT P1.email
FROM PERSON AS P1
CROSS JOIN PERSON AS P2
WHERE P1.email = P2.email
AND P1.id <> P2.id;
■ 마무리
오늘은 Leetcode 알고리즘 문제 '182. Duplicate Emails'에 대해서 알아봤습니다.
좋아요와 댓글 부탁드리며,
오늘 하루도 즐거운 날 되시길 기도하겠습니다 :)
감사합니다.
'PROGRAMMING > LeetCode' 카테고리의 다른 글
[Leetcode] 184. Department Highest Salary_해설, 풀이, 설명 (0) | 2023.01.21 |
---|---|
[Leetcode] 183. Customers Who Never Order_해설, 풀이, 설명 (0) | 2023.01.06 |
[Leetcode] 181. Employees Earning More Than Their Managers_해설, 풀이, 설명 (0) | 2022.09.12 |
[Leetcode] 180. Consecutive Numbers_해설, 풀이, 설명 (0) | 2022.09.03 |
[Leetcode] 178. Rank Scores_해설, 풀이, 설명 (0) | 2022.08.21 |
댓글