문제
data:image/s3,"s3://crabby-images/d0db9/d0db9a1470e39a6d752660ff231863c9ad88704a" alt="백준(Python) 13417: 카드 문자열 1 백준(Python) 13417: 카드 문자열"
https://www.acmicpc.net/problem/13417
풀이
사전 순서는 곧, 왼쪽에 있는 문자라면 가능한 작아야 한다는 것이다. 따라서, 카드를 하나씩 문자열에 넣을 때 가장 앞에 있는 문자와 비교하면 된다.
가장 앞에 있는 문자보다 작다면 왼쪽에 넣고, 아니라면 오른쪽에 넣으면 되는 것이다.
#13417
# 입력
t = int(input())
# 케이스 반복
for _ in range(t):
n = int(input())
cards = input().split()
card_list = []
# ord 함수를 이용하여, 비교.
start=cards[0]
for card in cards:
# 리스트 첫번째 요소보다, 작다면 왼쪽 삽입
if ord(card) <= ord(start):
card_list.insert(0, card)
start = card
# 만약 아니라면, 오른쪽 삽입
else:
card_list.append(card)
# 리스트 문자열 변환
card_str = ''.join(card_list)
print(card_str)
No Responses