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
기록
백준_5430_AC 본문
문제
https://www.acmicpc.net/problem/5430
풀이
1) two pointer
리스트를 직접 뒤집거나, 특정 원소를 제거하면 수행 시간이 오래 걸리므로 다른 방법을 생각했다.
- 리스트 뒤집기
리스트가 뒤집어 졌는지 여부를 저장하는 변수를 하나 두어, R이 나올 때 마다 이 값만 갱신했다.
- 원소 제거하기
리스트가 뒤집어지지 않았다면 왼쪽에서 원소를 꺼내고
리스트가 뒤집어졌다면 오른쪽에서 원소를 꺼낸다.
(deque를 활용해도 된다.)
직접 리스트를 수정하지 않고, start point와 end point를 두어
왼쪽에서 원소를 꺼내야 할 때는 start point += 1,
오른쪽에서 원소를 꺼내야 할 때는 end point -= 1
을 해주었다.
2) 예제 출력 형식
예제 출력을 보면 [2,1] 처럼 띄어쓰기를 포함하지 않도록 출력하고 있다.
arr = [1, 2, 3, 4]
print(arr)
위 코드처럼 리스트를 그냥 출력하면 [1, 2, 3, 4]로 공백이 포함된다.
(이걸 발견 못해서 오래 고생했다ㅠㅠ)
코드
def sol(p, n, arr) :
reverse = False
s, e = 0, n
for i in p :
if i=="R" : reverse ^= 1
elif i=="D":
if (s==e) : return "error"
if reverse : e-=1
else : s+=1
if reverse : return arr[s:e][::-1]
return arr[s:e]
import sys
T = int(input())
for _ in range(T) :
p = sys.stdin.readline().strip("\n")
n = int(sys.stdin.readline().strip("\n"))
arrinput = sys.stdin.readline().strip("\n").replace("[", "").replace("]", "").replace(" ", "")
if arrinput=="" : arr = list()
else : arr = list(arrinput.split(","))
ans = sol(p,n,arr)
if ans== "error" : print(ans)
else :
print("[", end = "")
print(",".join(ans), end = "")
print("]")
알고리즘
- 구현
- 자료 구조
- 문자열
- 파싱
- 덱
'코딩테스트 > python' 카테고리의 다른 글
프로그래머스_python_모두 0으로 만들기 (0) | 2021.12.26 |
---|---|
프로그래머스_경주로 건설 (0) | 2021.12.26 |
프로그래머스_python_퍼즐 조각 채우기 (1) | 2021.12.24 |
프로그래머스_python_보석 쇼핑 (0) | 2021.12.23 |
프로그래머스_python_교점에 별 만들기 (0) | 2021.12.22 |
Comments