[1874] 스택 수열(스택)

2023. 6. 3. 02:27·Coding Test/Data Structure
728x90
 

1874번: 스택 수열

1부터 n까지에 수에 대해 차례로 [push, push, push, push, pop, pop, push, push, pop, push, push, pop, pop, pop, pop, pop] 연산을 수행하면 수열 [4, 3, 6, 8, 7, 5, 2, 1]을 얻을 수 있다.

www.acmicpc.net

 

 

"""
1부터 n까지의 수를 스택에 넣었다가 뽑아 늘어놓음으로써, 하나의 수열을 만들 수 있다. 이때, 스택에 push하는 순서는 반드시 오름차순을 지키도록 한다고 하자.
임의의 수열이 주어졌을 때 스택을 이용해 그 수열을 만들 수 있는지 없는지, 있다면 어떤 순서로 push와 pop 연산을 수행해야 하는지를 알아낼 수 있다. 이를 계산하는 프로그램을 작성하라.

첫 줄에 n (1 ≤ n ≤ 100,000)이 주어진다. 둘째 줄부터 n개의 줄에는 수열을 이루는 1이상 n이하의 정수가 하나씩 순서대로 주어진다.
입력된 수열을 만들기 위해 필요한 연산을 한 줄에 한 개씩 출력한다. push연산은 +로, pop 연산은 -로 표현하도록 한다. 불가능한 경우 NO를 출력한다.
"""
n=int(input())
a=[0]*n # 수열 리스트
for i in range(n):
    a[i]=int(input())

stack=[]
idx=1

flag=True
res=''

for i in range(n):
    num=a[i]
    if num>=idx: # 현재 수열값 >= 오름차순 자연수 : 같아질때까지 append
        while num>=idx:
            stack.append(idx)
            idx+=1
            res+='+\n'
        stack.pop()
        res+='-\n'
    else: # 현재 수열값 < 오름차순 자연수 : pop
        nn=stack.pop()
        # 수열의 가장 위의 수가 만드어야하는 수열의 수보다 크면 수열 출력 불가
        if nn>num:
            print("NO")
            flag=False
            break
        else:
            res+='-\n'

if flag:
    print(res)

 

 

 

728x90
저작자표시 비영리 변경금지 (새창열림)
'Coding Test/Data Structure' 카테고리의 다른 글
  • [2164] 카드2 (큐, 덱)
  • [12891] DNA 비밀번호 (슬라이딩 윈도우)
  • [2018] 수들의 합 5 (투 포인터)
  • [1940] 주몽 (투 포인터, 정렬)
Karla Ko
Karla Ko
𝘾𝙤𝙣𝙩𝙞𝙣𝙪𝙤𝙪𝙨𝙡𝙮 𝙄𝙢𝙥𝙧𝙤𝙫𝙞𝙣𝙜, 𝘾𝙤𝙣𝙨𝙩𝙖𝙣𝙩𝙡𝙮 𝘿𝙚𝙫𝙚𝙡𝙤𝙥𝙞𝙣𝙜 𝙔𝙚𝙨!
    250x250
  • Karla Ko
    karlaLog
    Karla Ko
  • 전체
    오늘
    어제
    • Total (467)
      • Spring (19)
      • JPA (4)
      • Cloud & Architecture (15)
        • Kubernetes (5)
        • Docker (3)
        • MSA (2)
        • GCP (1)
        • AWS (4)
      • Devops (1)
      • Message Queue (4)
        • Kafka (2)
        • RabbitMQ (2)
      • Git (4)
      • DB (4)
      • Java (9)
      • Python (4)
      • CS (11)
        • OS (8)
        • Network (2)
        • Algorithm (1)
      • Coding Test (392)
        • programmers (156)
        • Graph (43)
        • DP (37)
        • Search (31)
        • Tree (13)
        • Data Structure (26)
        • Combination (12)
        • Implement (18)
        • Geedy (23)
        • Sort (7)
        • Math (21)
        • geometry (2)
  • 블로그 메뉴

    • 홈
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    트리
    백준
    최단거리
    정렬
    플로이드워셜
    그래프
    DP
    프로그래머스
    재귀
    스택
    DFS
    Algorithm
    다익스트라
    LIS
    파이썬
    힙
    동적계획법
    최대공약수
    구간합
    자료구조
    이분탐색
    큐
    그리디
    월간코드챌린지
    구현
    조합
    BFS
    최소신장트리
    덱
    알고리즘
  • hELLO· Designed By정상우.v4.10.3
Karla Ko
[1874] 스택 수열(스택)
상단으로

티스토리툴바