목차
- 문제 개요
- 풀이
- Solution
- 제출 결과
문제 개요
난이도 - MEDIUM
사용 언어 - C++
연결 리스트가 주어지면 근접한 한 노드와 짝을 지어 두 노드를 swap 합니다. 이때 노드의 값을 변경하는 것은 허락되지 않고 오직 노드의 next 포인터만 수정가능합니다.
위 이미지와 같이 한 쌍의 노드를 swap합니다.
문제 - LeetCode - 24. Swap Nodes in Pairs
풀이
My Solutions(Github)
Solution
사실 난이도가 medium으로 측정되어 있지만, 단순히 두 연결 리스트의 next 포인터를 swap만 하면 되는 문제입니다.
일반적으로 맨 처음 컴퓨터 언어에 대한 tutorial에서 두 변수를 swap하는 예제와 상당히 유사합니다.
다만 차이점이라면 순방향 연결 리스트이기 때문에 약간의 처리가 필요합니다.
실질적인 실행 코드는 단 10줄 가량으로 정리됩니다. 추가적인 설명은 하지 않도록 하겠습니다.
제출 결과
난이도가 medium으로 측정된것과 다르게 사실상 easy 난이도나 다름 없었습니다.
종종 느끼지만 leetcode에서 측정하는 난이도는 상당히 이상하다고 느껴지는 점이 종종 있는 것 같습니다.
코드 전문