[백준] 1976번: 여행 가자 - Kotlin[코틀린]

2023. 11. 3. 01:50·알고리즘/Baekjoon

문제

 

 

1976번: 여행 가자

동혁이는 친구들과 함께 여행을 가려고 한다. 한국에는 도시가 N개 있고 임의의 두 도시 사이에 길이 있을 수도, 없을 수도 있다. 동혁이의 여행 일정이 주어졌을 때, 이 여행 경로가 가능한 것인

www.acmicpc.net

 


풀이

 

 유니온 파인드(Union-Find)를 활용한 문제다. 도시들의 연결 정보를 입력받아 합집합(Union) 연산을 수행하고 여행 계획에 포함되어 있는 도시들이 합집합인지 아닌지 판별하여 결과를 출력하면 된다.

 


코드

 

import java.util.*

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

    var st : StringTokenizer
    val num = br.readLine().toInt()
    val city = br.readLine().toInt()

    val parent = IntArray(num + 1) { it }
    fun find(a: Int): Int {
        return if(a == parent[a]) a
        else {
            parent[a] = find(parent[a])
            parent[a]
        }
    }
    fun union(a: Int, b: Int) {
        val x = find(a)
        val y = find(b)
        if(x < y) {
            parent[y] = x
        } else {
            parent[x] = y
        }
    }

    for(i in 1 .. num) {
        st = StringTokenizer(br.readLine())
        for(j in 1 .. num) {
            if(st.nextToken().toInt() == 1) { // 1인 경우 유니온 연산
                union(i, j)
            }
        }
    }
    st = StringTokenizer(br.readLine())
    val start = parent[st.nextToken().toInt()]
    var check = "YES"
    for(i in 1 until city) {
        if(parent[st.nextToken().toInt()]!=start) { // 도시가 합집합이 아닌 경우
            check = "NO"
            break
        }
    }

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

 

 

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

[백준] 20040번: 사이클 게임 - Kotlin[코틀린]  (0) 2023.11.07
[백준] 4195번: 친구 네트워크 - Kotlin[코틀린]  (0) 2023.11.06
[백준] 1922번: 네트워크 연결 - Kotlin[코틀린]  (0) 2023.11.01
[백준] 1717번: 집합의 표현 - Kotlin[코틀린]  (0) 2023.10.31
[백준] 2636번: 치즈 - Kotlin[코틀린]  (0) 2023.10.27
'알고리즘/Baekjoon' 카테고리의 다른 글
  • [백준] 20040번: 사이클 게임 - Kotlin[코틀린]
  • [백준] 4195번: 친구 네트워크 - Kotlin[코틀린]
  • [백준] 1922번: 네트워크 연결 - Kotlin[코틀린]
  • [백준] 1717번: 집합의 표현 - Kotlin[코틀린]
junghoooooon
junghoooooon
  • junghoooooon
    코드팁스
    junghoooooon
  • 전체
    오늘
    어제
    • 전체 (120)
      • 안드로이드 (0)
        • 코드팁스 (0)
      • 유니티 (0)
        • 코드팁스 (0)
      • 알고리즘 (118)
        • 알고리즘 (0)
        • Baekjoon (118)
      • GitHub (0)
      • 티스토리 (2)
  • 블로그 메뉴

    • 링크

    • 공지사항

    • 인기 글

    • 태그

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

    티스토리툴바