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
- 1차원 DP
- 2차원 dp
- 99클럽
- @Builder
- @Entity
- @GeneratedValue
- @GenericGenerator
- @NoargsConstructor
- @Query
- @Table
- @Transactional
- Actions
- Amazon EFS
- amazon fsx
- Android Studio
- ANSI SQL
- ApplicationEvent
- assertThat
- async/await
- AVG
- AWS
- Azure
- bind
- builder
- button
- c++
- c++ builder
- c03
- Callback
- case when
Archives
- Today
- Total
기록
프로그래머스_표 편집 본문
문제
https://programmers.co.kr/learn/courses/30/lessons/81303
풀이
Linked List
노드의 포인터가 다음이나 이전의 노드와의 연결을 담당
# Linked List
nodes = {i:[(i+n-1)%n, (i+1)%n] for i in range(n)}
- 삽입 Z
- 삭제 C
어려웠던 부분
1. 되돌리기
되돌리기를 할 때 링크드 리스트 전체를 stack에 저장했다. 그래서 그런지 효율성 테스트를 통과하지 못했다. 다른 사람들의 코드를 보니 노드 하나만을 저장하더라!
2. 링크드 리스트
굳이 원형으로 연결되어야 할까?라는 생각에 아래와 같이 표현하였다. 이렇게 표현하니 코드가 중간에 꼬이더라...
코드
def solution(n, k, cmd):
# Linked List
nodes = {i:[(i+n-1)%n, (i+1)%n] for i in range(n)}
stack = list()
for c in cmd :
if "U" in c : # ↑
m = int(c.split()[-1])
for i in range(m) : k = nodes[k][0]
elif "D" in c : # ↓
m = int(c.split()[-1])
for i in range(m) : k = nodes[k][1]
elif "C" in c :
# disconnect
pre, post = nodes[k]
nodes[pre][1] = nodes[k][1]
nodes[post][0] = nodes[k][0]
stack.append([k, *nodes[k]])
# delete
tmp = nodes[k]
del nodes[k]
# point
if tmp[1]==0 : k = tmp[0]
else : k = tmp[1]
elif "Z" in c : # 끼워넣기
cur, pre, post = stack.pop()
nodes[cur] = [pre, post]
nodes[pre][1] = cur
nodes[post][0] = cur
ans = ""
for i in range(n) :
if i in nodes : ans += "O"
else : ans += "X"
return ans
'코딩테스트 > python' 카테고리의 다른 글
프로그래머스_피로도 (0) | 2021.12.13 |
---|---|
프로그래머스_거리두기 확인하기 (0) | 2021.08.28 |
[수정중] 백준_4811_알약 (0) | 2021.08.09 |
프로그래머스_스티커 모으기(2) (0) | 2021.06.16 |
프로그래머스_110 옮기기 (0) | 2021.05.31 |
Comments