[프로그래머스] 전력망을 둘로 나누기 (kotlin)

2025. 3. 11. 18:59·공부/코딩테스트 | 알고리즘

문제

n개의 송전탑이 전선을 통해 하나의 트리 형태로 연결되어 있습니다.
당신은 이 전선들 중 하나를 끊어서 현재의 전력망 네트워크를 2개로 분할하려고 합니다.
이때, 두 전력망이 갖게 되는 송전탑의 개수를 최대한 비슷하게 맞추고자 합니다.

송전탑의 개수 n, 그리고 전선 정보 wires가 매개변수로 주어집니다. 
전선들 중 하나를 끊어서 송전탑 개수가 가능한 비슷하도록 두 전력망으로 나누었을 때, 
두 전력망이 가지고 있는 송전탑 개수의 차이(절대값)를 return 하도록 solution 함수를 완성해주세요.

 

제한사항

  • n은 2 이상 100 이하인 자연수입니다.
  • wires는 길이가 n-1인 정수형 2차원 배열입니다.
    • wires의 각 원소는 [v1, v2] 2개의 자연수로 이루어져 있으며, 이는 전력망의 v1번 송전탑과 v2번 송전탑이 전선으로 연결되어 있다는 것을 의미합니다.
    • 1 ≤ v1 < v2 ≤ n 입니다.
    • 전력망 네트워크가 하나의 트리 형태가 아닌 경우는 입력으로 주어지지 않습니다.

 


풀기

트리 문제로 보였다. 그래서 DFS or BFS로 풀어야 할 것 같은 생각을 가지고 문제를 봤다.

송전탑의 개수를 세어야 하기 때문에 DFS로 Depth 체크하는건 아니라 BFS로 개수를 체크해야 한다고 생각했는데 쓰면서 생각해보니까 DFS로도 체크할 수 있을듯..?

 

꼼수가 있을까 생각해봤는데 없는것 같았고 완전탐색으로 분류된 문제라 간선 하나하나 제거하면서 송전탑 개수를 세고 최솟값을 리턴해야겠다고 생각했다.


결과

class Solution {
    private val map = mutableMapOf<Int, MutableList<Int>>()

    fun solution(
        n: Int,
        wires: Array<IntArray>
    ): Int {

        var result = n

        for (i in 1 .. n) {
            map.put(i, mutableListOf())
        }

        for (i in 0 until wires.size) {
            map[wires[i][0]]?.add(wires[i][1])
            map[wires[i][1]]?.add(wires[i][0])
        }

        // 간선 하나씩 제거하면서 계산
        for (wire in wires) {

            map[wire[0]]?.remove(wire[1])
            map[wire[1]]?.remove(wire[0])

            val count = BFS(wire[0], n)
            val remainCount = n - count
            val diff = Math.abs(count - remainCount)

            if (result > diff) {
                result = diff
            }

            map[wire[0]]?.add(wire[1])
            map[wire[1]]?.add(wire[0])

        }

        return result
    }

    private fun BFS(
        number: Int,
        n: Int
    ): Int {

        val visited = Array(n + 1) { false }
        val queue = LinkedList<Int>()

        queue.add(number)
        visited[number] = true

        while (!queue.isEmpty()) {
            val node = queue.pop()

            for (n in map[node] ?: listOf()) {
                if (!visited[n]) {
                    queue.add(n)
                    visited[n] = true
                }
            }
        }

        return visited.count { it == true }

    }

}

 

'공부 > 코딩테스트 | 알고리즘' 카테고리의 다른 글

[LeetCode] Validate Binary Search Tree  (1) 2025.03.01
[LeetCode] Maximum Depth of Binary Tree  (0) 2025.02.27
[LeetCode] Min Stack  (0) 2025.02.26
[LeetCode] House Robber  (0) 2025.02.25
[LeetCode] Maximum Subarray  (0) 2025.02.24
'공부/코딩테스트 | 알고리즘' 카테고리의 다른 글
  • [LeetCode] Validate Binary Search Tree
  • [LeetCode] Maximum Depth of Binary Tree
  • [LeetCode] Min Stack
  • [LeetCode] House Robber
나는 유찌
나는 유찌
쩌리쨩
  • 나는 유찌
    유찌 개발 일기
    나는 유찌
  • 전체
    오늘
    어제
    • 분류 전체보기
      • 사이드 프로젝트
        • 게시판
        • 블로그(Spring boot + React.js ..
      • 데이터베이스
        • SQLD
      • 이슈 해결
      • Front
        • Javascript
        • Vue.js
        • HTML+CSS
      • Backend
        • Spring
        • ORM
        • JAVA
      • 공부
        • HTTP
        • OOP
        • 이것저것
        • 코딩테스트 | 알고리즘
      • Computer Science
        • Computer architecture
        • 데이터베이스
        • 운영체제
      • 일상
        • 독서
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    Spring Boot
    access token
    refresh token
    Kotlin AccessDecisionManager
    권한 scope 처리
    독서
    mysql 격리수준
    LeetCode
    redis 분산락
    Spring boot에서 JWT 구현
    추리소설
    AccessDecisionVoter
    spring 격리수준
    AntPathMatcher
    Spring Security AccessDecisionManager
    Access Token Refresh Token
    mssql
    DIRTY READ
    Access token 재발급
    spring
    role scope
    JWT이란?
    phantom read
    한국소설
    jwt 로그인 구현
    jwt
    Kotlin AntPathMatcher
    히가시노 게이고
    pessimisticlock
    웹 개발
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
나는 유찌
[프로그래머스] 전력망을 둘로 나누기 (kotlin)
상단으로

티스토리툴바