반응형
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 리트코드
- 파이썬
- python
- OS
- web
- 웹프로그래밍
- javascript
- dp
- sql
- Medium
- 프로그래머스
- react
- 리액트
- Level3
- VUE
- Doitvue.js입문
- LeetCode
- 자바스크립트
- Level2
- 코테연습
- 백준
- typescript
- 배열
- 프로그래밍
- C++
- 고득점Kit
- 동적계획법
- CS
- 카카오
- Level1
Archives
- Today
- Total
[리트코드] 283. Move Zeroes 본문
반응형
283. Move Zeroes
in place(나머지 숫자의 순서를 바꾸지 않고) 로 0을 오른쪽으로 옮기기
[0, 5, 0, 7, 6, 3]
0을 무조건 오른쪽으로 옮긴다면?
나머지 숫자를 한 칸씩 앞으로 옮겨야하므로 오퍼레이션이 복잡해짐
0을 버블 스왑한다면 ?
O(n * 0의 개수)로 시간 복잡도가 너무 커짐
basic Idea
0을 찾아서 옮긴다면 나머지 숫자들의 순서가 바뀌지 않아야 하므로 버블 스왑 할 수 밖에 없음
그렇다면 0이 아닌 숫자를 찾아서 왼쪽으로 옮긴다면? 숫자만 옮기면 되니까 순서가 바뀔 일이 없음
[0,0,0,0,5,9,3]
[5,0,0,0,0,9,3]
[5,9,0,0,0,0,3]
[5,9,3,0,0,0,0]
투포인터를 사용한다.
start : 0을 가리킴
end : 0이 아닌 숫자를 가리킴
- end 포인터를 한 칸씩 움직이며 0이 아닌 숫자를 찾는다.
- start에 있는 0과 스왑한다.
- start를 오른쪽으로 한칸 옮긴다.
class Solution:
def moveZeroes(self, nums: List[int]) -> None:
z_idx = 0
for i in range(len(nums)):
if nums[i] != 0:
nums[z_idx], nums[i] = nums[i], nums[z_idx]
z_idx += 1
반응형
'코테 문제 풀이' 카테고리의 다른 글
[리트코드] 209. Minimum Size Subarray Sum (0) | 2022.04.11 |
---|---|
[리트코드] 724. Find Pivot Index (0) | 2022.04.11 |
[프로그래머스] 구명보트 - python (0) | 2022.04.09 |
[프로그래머스] 징검다리 - python (0) | 2022.04.08 |
[프로그래머스] 입국심사 - python (0) | 2022.04.08 |
Comments