일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 20201011뉴스
- json
- 헤드라인모음
- 헤드라인
- 20201017뉴스
- 헤드라인뉴스
- encoding
- 20201018뉴스
- 기사헤드라인
- LeetCode #Python #알고리즘 #코딩테스트 #interview
- 20201016뉴스
- 오늘의뉴스
- 코테
- 백준
- 경제뉴스
- 20201013뉴스
- 20201015뉴스
- 알고리즘
- MySQL
- 기사
- 20200816뉴스
- 헤드라인기사
- Python
- 백준2225
- 뉴스
- 뉴스헤드라인
- 20200615뉴스
- 크롤링
- C++
- 파이썬
Archives
- Today
- Total
HelloCho
[Python] #189. Rotate Array(easy) 본문
문제
이 문제는 list가 주어질때 오른쪽으로 k index만큼 옮기는 문제이다.
처음 시도한 방법.
class Solution:
def rotate(self, nums: List[int], k: int) -> None:
"""
Do not return anything, modify nums in-place instead.
"""
for i in range(k):
data = nums.pop()
nums.insert(0,data)
처음 시도한 방법은 가장 마지막 값을 pop시켜서 nums에 0번 index에 값을 넣어줬다.
결과
..많이 느린 것 같다. 원인은 insert로 값을 넣다보니 값을 하나씩 다 미뤄야해서 오래걸리는 것!
그래서 다음 시도한 방법은 k개씩 옮기면 어느위치에 값이 가는지 이미(?) 알고있으니 값을 옮기는 방법이다.
class Solution:
def rotate(self, nums: List[int], k: int) -> None:
n = len(nums)
a = [0] * n
for i in range(n):
a[(i + k) % n] = nums[i]
nums[:] = a
a의 값을 0으로 [0]배열로 초기화시켜준다.
(i+k) $n으로 값을 해주면 아주 간단하게 ? 문제 해결가능
그리고 inplace형식으로 문제를 해결해야하기 때문에 nums[:] 식으로 a값을 넣어준다.
확실히 더 빠른속도로 문제 해결가능 !
'코테 > LeetCode' 카테고리의 다른 글
[Python] #134. Gas Station(Medium) (0) | 2020.10.01 |
---|---|
[Python] #H-Index2(Medium) (0) | 2020.09.30 |
[Python] #274. H-Index(Medium) (0) | 2020.09.30 |
[Python] #125. Valid Palindrome(easy) (0) | 2020.09.30 |
[Python] #204. Count Primes(easy) (0) | 2020.09.30 |
Comments