[백준] 2346번: 풍선 터트리기 - Kotlin[코틀린]

2023. 12. 11. 19:39·알고리즘/Baekjoon

문제

 

 

2346번: 풍선 터뜨리기

1번부터 N번까지 N개의 풍선이 원형으로 놓여 있고. i번 풍선의 오른쪽에는 i+1번 풍선이 있고, 왼쪽에는 i-1번 풍선이 있다. 단, 1번 풍선의 왼쪽에 N번 풍선이 있고, N번 풍선의 오른쪽에 1번 풍선

www.acmicpc.net

 


풀이

 

 이 문제는 Deque(덱)을 이용해 풀이하면 된다. 덱은 양쪽에서 삽입과 삭제가 모두 가능한 자료구조이다.

 

 풍선의 번호와 풍선에 적혀 있는 숫자를 저장할 풍선 data class를 정의하고, 이를 이용하여 입력 받은 수를 덱에 저장한다. 그 후, 덱이 비어질 때까지 반복하면서 풍선을 터뜨리는 순서를 구하면 된다.

 

 덱의 첫번째 풍선을 터뜨리고, 풍선에 적힌 숫자에 따라 덱을 업데이트한다. 숫자가 양수인 경우, 덱의 앞부분에 있는 풍선을 'poll()' 하면서 그 풍선을 덱의 뒷부분에 'add()' 해주면 된다. 예를 들어, 덱에 있는 숫자가 [2, 3, -1, -2, 1]인 경우, 2만큼 이동시켜주면 [-1, -2, 1, 2, 3]이 된다. 음수인 경우에는 이와 반대로 처리해준다.

 


코드

 

import java.util.*

data class Balloon(val idx: Int, val move: Int)

fun main() {
    val br = System.`in`.bufferedReader()
    val bw = System.out.bufferedWriter()

    val num = br.readLine().toInt()
    val deque : Deque<Balloon> = ArrayDeque()
    val st = StringTokenizer(br.readLine())
    for(i in 1 .. num) {
        deque.add(Balloon(i, st.nextToken().toInt()))
    }

    val sb = StringBuilder()

    while (true) {
        val cur = deque.poll()
        sb.append("${cur.idx} ")
        val move = cur.move

        if(deque.isEmpty()) break

        if(move > 0) {
            for(i in 1 until move) {
                deque.addLast(deque.pollFirst())
            }
        } else {
            for(i in move until 0) {
                deque.addFirst(deque.pollLast())
            }
        }
    }

    bw.write(sb.toString())
    bw.flush()
    bw.close()
    br.close()
}

 

'알고리즘 > Baekjoon' 카테고리의 다른 글

[백준] 2669번: 직사각형 네개의 합집합의 면적 구하기 - Kotlin[코틀린]  (0) 2023.12.13
[백준] 1339번: 단어 수학 - Kotlin[코틀린]  (0) 2023.12.11
[백준] 2504번: 괄호의 값 - Kotlin[코틀린]  (0) 2023.12.05
[백준] 4485번: 녹색 옷 입은 애가 젤다지? - Kotlin[코틀린]  (0) 2023.11.30
[백준] 2529번: 부등호 - Kotlin[코틀린]  (0) 2023.11.29
'알고리즘/Baekjoon' 카테고리의 다른 글
  • [백준] 2669번: 직사각형 네개의 합집합의 면적 구하기 - Kotlin[코틀린]
  • [백준] 1339번: 단어 수학 - Kotlin[코틀린]
  • [백준] 2504번: 괄호의 값 - Kotlin[코틀린]
  • [백준] 4485번: 녹색 옷 입은 애가 젤다지? - Kotlin[코틀린]
junghoooooon
junghoooooon
  • junghoooooon
    코드팁스
    junghoooooon
  • 전체
    오늘
    어제
    • 전체 (120)
      • 안드로이드 (0)
        • 코드팁스 (0)
      • 유니티 (0)
        • 코드팁스 (0)
      • 알고리즘 (118)
        • 알고리즘 (0)
        • Baekjoon (118)
      • GitHub (0)
      • 티스토리 (2)
  • 블로그 메뉴

    • 링크

    • 공지사항

    • 인기 글

    • 태그

      스택
      구현
      누적 합
      MST
      재귀
      정렬
      분할 정복
      유니온파인드
      수학
      브루트포스
      그래프이론
      백트래킹
      이분 탐색
      우선순위 큐
      그래프 탐색
      프림
      문자열
      그리디
      DP
      큐
      분리집합
      모듈러 곱셈 역원
      소수 판정
      에라토스테네스의 체
      크루스칼
      투 포인터
      피보나치
      BFS
      티스토리
      dfs
    • hELLO· Designed By정상우.v4.10.2
    junghoooooon
    [백준] 2346번: 풍선 터트리기 - Kotlin[코틀린]
    상단으로

    티스토리툴바