Notice
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- aws
- 월미도
- 쿠버네티스
- Spring Data JPA
- 알고리즘
- JPA
- 클라우드 컴퓨팅
- 코드업
- gcp
- 자료구조
- Spring
- 오일러프로젝트
- Kafka
- DFS
- Apache Kafka
- 스프링 부트
- Docker
- 인천여행
- springboot
- 클라우드
- VPC
- 백준
- 스프링부트
- Elasticsearch
- Spring Boot
- 카프카
- 백트래킹
- 스프링
- 프로그래밍문제
- 로드밸런서
Archives
- Today
- Total
GW LABS
[Backjoon] 단어 뒤집기 2 본문
문자열을 뒤집는 문제는 프로그래머의 기본이 되어있는지 판단할 수 있는 문제라고 한다. 17413번 단어 뒤집기 2는 단순히 배열을 뒤집는 것에서 넘어 특정 조건에 맞는 문자열만 뒤집는 문제이다.
투 포인터와 큐를 이용해서 풀면 되겠다고 생각했고, 깔끔하지 못한 코딩이였지만 한번에 정답을 맞출 수 있었다. 다른 사람들의 풀이를 보면 문자열을 문자단위로 분해해서 순회하는 방법, 스택을 이용하는 방법들도 있었다. 아래는 소스코드이다.
import sys
from collections import deque
if __name__ == "__main__":
q = deque()
target_string = sys.stdin.readline().replace("\n", "")
idx_start, idx_end = 0, 0
is_tag_open = False
while idx_start < len(target_string):
if target_string[idx_start] == "<":
while idx_end < len(target_string) and target_string[idx_end] != ">" :
idx_end += 1
idx_end += 1
q.append(target_string[idx_start:idx_end])
idx_start = idx_end
else:
while idx_end < len(target_string) and target_string[idx_end] != "<":
idx_end += 1
q.append(target_string[idx_start:idx_end])
idx_start = idx_end
answer_string = ""
while q:
string = q.popleft()
if "<" in string:
answer_string += string
else:
temp_arr = string.split(" ")
temp_arr = [temp[::-1] for temp in temp_arr]
answer_string += " ".join(temp_arr)
print(answer_string)
'Algorithm & DataStructure' 카테고리의 다른 글
[Backjoon] 저울 (0) | 2020.12.07 |
---|---|
[Backjoon] 영역 구하기 (0) | 2020.11.30 |
[Backjoon] 섬의 개수 (0) | 2020.11.18 |
[Backjoon] 쉬운 계단 수 (0) | 2020.11.11 |
[Backjoon] 정수 삼각형 (0) | 2020.11.05 |
Comments