[백준] 1138번: 한 줄로 서기 - Kotlin[코틀린]

2024. 1. 1. 19:47·알고리즘/Baekjoon

문제

 

 

1138번: 한 줄로 서기

첫째 줄에 사람의 수 N이 주어진다. N은 10보다 작거나 같은 자연수이다. 둘째 줄에는 키가 1인 사람부터 차례대로 자기보다 키가 큰 사람이 왼쪽에 몇 명이 있었는지 주어진다. i번째 수는 0보다

www.acmicpc.net

 


풀이

 

 for문과 배열을 활용해 풀이하였다.

 

 먼저 사람을 자리에 배치하기위한 빈 배열을 선언한다. 배열에는 1번부터 순서대로 배치하는데 0의 개수를 세어 위치를 정해주면 된다. 순서대로 배치하기 때문에 0의 개수는 자신보다 큰 사람이 위치할 수 있는 자리의 숫자이다. 이 숫자가 입력 받은 숫자와 같다면 현재 번호를 배치할 수 있는 것이다. 만약 자리에 이미 누군가 있다면 그 뒤에 배치해준다.

 


코드

 

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

    val num = br.readLine().toInt()
    val arr = br.readLine().split(' ').map { it.toInt() }
    val ans = IntArray(num)

    for(i in 0 until num) {
        var cnt = 0
        for(j in 0 until num) {
            if(ans[j] == 0) {
                if(cnt == arr[i]) {
                    if(ans[j] == 0) {
                        ans[j] = i + 1
                        break
                    }
                } else {
                    cnt++
                }
            }
        }
    }

    ans.forEach {
        bw.append("$it ")
    }

    bw.write("")
    bw.flush()
    bw.close()
    br.close()
}

 

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

[백준] 2573번: 빙산 - Kotlin[코틀린]  (0) 2024.01.03
[백준] 1431번: 시리얼 번호 - Kotlin[코틀린]  (0) 2024.01.02
[백준] 10826번: 피보나치 수 4 - Kotlin[코틀린]  (1) 2023.12.28
[백준] 2578번: 빙고 - Kotlin[코틀린]  (0) 2023.12.27
[백준] 1743번: 음식물 피하기 - Kotlin[코틀린]  (0) 2023.12.21
'알고리즘/Baekjoon' 카테고리의 다른 글
  • [백준] 2573번: 빙산 - Kotlin[코틀린]
  • [백준] 1431번: 시리얼 번호 - Kotlin[코틀린]
  • [백준] 10826번: 피보나치 수 4 - Kotlin[코틀린]
  • [백준] 2578번: 빙고 - Kotlin[코틀린]
junghoooooon
junghoooooon
  • junghoooooon
    코드팁스
    junghoooooon
  • 전체
    오늘
    어제
    • 전체 (120)
      • 안드로이드 (0)
        • 코드팁스 (0)
      • 유니티 (0)
        • 코드팁스 (0)
      • 알고리즘 (118)
        • 알고리즘 (0)
        • Baekjoon (118)
      • GitHub (0)
      • 티스토리 (2)
  • 블로그 메뉴

    • 링크

    • 공지사항

    • 인기 글

    • 태그

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

    티스토리툴바