lag, leag 강의에서 game-play-analysis-iv 문제
https://leetcode.com/problems/game-play-analysis-iv/
이 문제를 풀고 있는데,
제가 작성한 코드는
SELECT ROUND(COUNT(player_id) /(SELECT COUNT(DISTINCT player_id) FROM Activity),2) as fraction
FROM
(
SELECT player_id,
LAG(player_id) OVER (ORDER BY player_id) AS prev_id,
LAG(event_date) OVER (ORDER BY player_id) AS prev_date,
event_date,
RANK() OVER (PARTITION BY player_id ORDER bY event_date) AS rnk
FROM Activity
) A
WHERE rnk = 2
AND DATE_ADD(prev_date, INTERVAL 1 day) = event_date AND player_id = prev_id
입니다. 이 코드로 정답을 체크해 보았을 때 wrong answer라 뜨지만, A FROM절 안에서 event_date, rnk의 순서를 LAG 앞으로 바꾸어 주었을 땐 정답 처리가 되었습니다. 왜 그런걸까요??
아래는 순서를 바꿨을 때 정답처리 되었던 코드 입니다.
SELECT ROUND(COUNT(player_id) /(SELECT COUNT(DISTINCT player_id) FROM Activity),2) as fraction
FROM
(
SELECT player_id,
event_date,
RANK() OVER (PARTITION BY player_id ORDER bY event_date) AS rnk,
LAG(player_id) OVER (ORDER BY player_id) AS prev_id,
LAG(event_date) OVER (ORDER BY player_id) AS prev_date
FROM Activity
) A
WHERE rnk = 2
AND DATE_ADD(prev_date, INTERVAL 1 day) = event_date AND player_id = prev_id
답변 2
1
Soiejung 님,
컬럼의 순서에 따라 정답/오답이 결정나는 것은 아니였고, right answer라고 나온 두번째 코드는 test case를 모두 통과해서 옳은 정답으로 우연히 나온 것입니다. wrong answer라고 나온 첫번째 코드 기준으로 설명 드리겠습니다.
일단 Soiejung님께서 첨부해주신 코드 중
LAG(event_date) OVER (ORDER BY player_id) AS prev_date
가 아닌,
LAG(event_date) OVER (ORDER BY player_id, event_date) AS prev_date
로 작성해야 됩니다. (강의 코드 기준)
그래야지 아래 그림처럼, 해당 player_id의 직전 event_date가 순서대로 나옵니다.

다만, 제가 강의에서 간과했던 부분이 prev_id도
LAG(player_id) OVER (ORDER BY player_id, event_date) AS prev_id
로 ORDER BY event_date를 추가해야 됩니다.
prev_id에 ORDER BY event_date를 추가하지 않는다면, 아래 그림처럼 prev_date와 동일하게 null로 찍혀야 되는 row가 서로 달라지게 됩니다.

따라서 prev_date처럼, prev_id에도 동일하게 ORDER BY event_date를 추가해줘야 합니다.
그럼 아래처럼 동일한 row에 대해서 null로 찍히게 될 것입니다.

따라서 Soiejung 님께서 2번째 코드로 right answer라고 나온 부분은 우연히 모든 test case를 통과해서 맞은 것처럼 나왔지만 실제로 틀린 코드입니다. 1번째 코드의 prev_id와 prev_date를 올바르게 수정해서 다시 돌린다면, right answer로 나오게 될 것입니다.
추후 prev_id 코드에 대해서 강의 수정 진행하도록 하겠습니다.
읽어보시고, 이해가 안가신다면 편하게 다시 질문 부탁드립니다! :)
0
Soiejung 님, 안녕하세요.
Soiejung님 버전 코드까지 같이 첨부해주셔서 제가 답변하기가 훨씬 수월해졌는데요 :)
위에 질문에 대한 답변은 이번주 일요일까지 드리겠습니다! 답변 바로 드리지 못한 점 양해부탁드립니다.
백준 사이트 서버종료
0
4
0
살구 클럽에 대한 질문있습ㄴ디ㅏ
0
18
1
[할인쿠폰] 코테의 바이블[JAVA] 50% 할인 쿠폰 관련
0
7
1
GROUP BY 시 인덱스를 타지 않는 이유가 궁금합니다
0
14
1
FOREIGN KEY 정리하기, 영상대로 SQL코드 복붙해도 안되요.
0
18
1
모델 서빙과 관련된 강좌 출시 예정된 바가 있으신지 여쭤봅니다!
0
22
2
Vercel 실행이 안됩니다
0
16
1
교안 158페이지 문의드립니다
0
28
2
코딩살구클럽 관련 건의사항
0
67
1
코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다
0
29
1
수강평 이벤트
0
24
2
패키지 구분에 대해 궁금한게 있습니다
0
18
2
진행 방법 질문드립니다!
0
62
2
노션 링크도 안 열리고, 알려준 vercel도 실행이 안됩니다.
0
21
1
안녕하세요. 바뀐 채점사이트 관련해서 문의드립니다.
0
19
1
스프링부트 서버 에러나요
0
20
1
코드를 첨부해야하는 이유가 있나요?
0
23
2
갑자기 채점 사이트가 바뀌었어요
0
24
1
간단한 오타 제보입니다.
0
21
1
문제 리스트 페이지
0
24
1
part8 Notion 링크
0
25
1
큰 범위 조회 시 EXPLAIN의 rows 값이 정확하지 않은 이유가 궁금합니다.
0
39
2
LAG, LEAD 강의 550. Game Play Analysis IV 관련 질문
1
164
2
Date 강의 / leetcode 1321 질문
1
197
1





