[백준] 5052번: 전화번호 목록 - Kotlin[코틀린]

2024. 3. 27. 20:39·알고리즘/Baekjoon

문제

 

 

5052번: 전화번호 목록

첫째 줄에 테스트 케이스의 개수 t가 주어진다. (1 ≤ t ≤ 50) 각 테스트 케이스의 첫째 줄에는 전화번호의 수 n이 주어진다. (1 ≤ n ≤ 10000) 다음 n개의 줄에는 목록에 포함되어 있는 전화번호가

www.acmicpc.net

 


풀이

 

 전화번호를 문자열로 입력받고 이를 정렬하여 번호를 비교하는 방식으로 해결할 수 있다.

 

 예를 들어, 예제 입력1의 테스트 케이스인 911, 97625999, 91125426을 입력받은 경우, 이를 오름차순으로 정렬하면 911, 91125426, 97625999 가 된다. 여기서 startsWith() 함수를 사용하여 이전의 번호가 다음 번호에 포함되는지 여부를 확인할 수 있다. 이를 통해 전화번호 목록이 일관성 있는 목록인지 판단할 수 있다.

 


코드

 

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

    val sb = StringBuilder()
    repeat(br.readLine().toInt()) {
        val num = br.readLine().toInt()
        val arr = Array(num) { br.readLine() }
        arr.sort()
        sb.append(if(check(arr)) "YES\n" else "NO\n")
    }

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

fun check(arr: Array<String>): Boolean {
    for(i in 1 until arr.size) {
        if(arr[i].startsWith(arr[i-1])) {
            return false
        }
    }
    return true
}

 

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

[백준] 11441번: 합 구하기 - Kotlin[코틀린]  (0) 2024.04.09
[백준] 11047번: 동전 0 - Kotlin[코틀린]  (0) 2024.04.01
[백준] 1913번: 달팽이 - Kotlin[코틀린]  (0) 2024.03.22
[백준] 11501번: 주식 - Kotlin[코틀린]  (0) 2024.03.20
[백준] 13301번: 타일 장식물 - Kotlin[코틀린]  (0) 2024.03.17
'알고리즘/Baekjoon' 카테고리의 다른 글
  • [백준] 11441번: 합 구하기 - Kotlin[코틀린]
  • [백준] 11047번: 동전 0 - Kotlin[코틀린]
  • [백준] 1913번: 달팽이 - Kotlin[코틀린]
  • [백준] 11501번: 주식 - Kotlin[코틀린]
junghoooooon
junghoooooon
  • junghoooooon
    코드팁스
    junghoooooon
  • 전체
    오늘
    어제
    • 전체 (120)
      • 안드로이드 (0)
        • 코드팁스 (0)
      • 유니티 (0)
        • 코드팁스 (0)
      • 알고리즘 (118)
        • 알고리즘 (0)
        • Baekjoon (118)
      • GitHub (0)
      • 티스토리 (2)
  • 블로그 메뉴

    • 링크

    • 공지사항

    • 인기 글

    • 태그

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

    티스토리툴바