[알고리즘] 전력망을 둘로 나누기

2023. 2. 3. 15:51·알고리즘
반응형

문제 설명

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

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

제한사항

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

입출력 예

n wires result
9 [[1,3],[2,3],[3,4],[4,5],[4,6],[4,7],[7,8],[7,9]] 3
4 [[1,2],[2,3],[3,4]] 0
7 [[1,2],[2,7],[3,7],[3,4],[4,5],[6,7]] 1

입출력 예 설명

입출력 예 #1

  • 다음 그림은 주어진 입력을 해결하는 방법 중 하나를 나타낸 것입니다.

  • 4번과 7번을 연결하는 전선을 끊으면 두 전력망은 각 6개와 3개의 송전탑을 가지며, 이보다 더 비슷한 개수로 전력망을 나눌 수 없습니다.
  • 또 다른 방법으로는 3번과 4번을 연결하는 전선을 끊어도 최선의 정답을 도출할 수 있습니다.

입출력 예 #2

  • 다음 그림은 주어진 입력을 해결하는 방법을 나타낸 것입니다.

  • 2번과 3번을 연결하는 전선을 끊으면 두 전력망이 모두 2개의 송전탑을 가지게 되며, 이 방법이 최선입니다.

입출력 예 #3

  • 다음 그림은 주어진 입력을 해결하는 방법을 나타낸 것입니다.

  • 3번과 7번을 연결하는 전선을 끊으면 두 전력망이 각각 4개와 3개의 송전탑을 가지게 되며, 이 방법이 최선입니다.

나의 풀이

function solution(n, wires) {
    var answer = 101;
    
    for(let i = 0; i < wires.length; i++) {
        const firstLine = new Set();
        const sliceWires = [...wires];
        
        let isLine = true
        
        sliceWires.splice(i, 1);
        
        const firstWire = sliceWires.pop()
        
        firstLine.add(firstWire[0])
        firstLine.add(firstWire[1])
        
        while(isLine) {
            isLine = false;
            let index = 0;
            
            while(index < sliceWires.length) {
                const currWire = sliceWires[index];
                
                if(firstLine.has(currWire[0]) || firstLine.has(currWire[1])){
                    sliceWires.splice(index, 1);
                    firstLine.add(currWire[0])
                    firstLine.add(currWire[1])
                    
                    isLine = true
                } else {
                    index ++;
                }
            }
        }
        
        const secondLineLength = n - firstLine.size;
        
        answer = Math.min(answer, Math.abs(firstLine.size - secondLineLength))
    }
    
    return answer;
}
반응형
저작자표시 비영리 변경금지 (새창열림)

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

[알고리즘] 콜라 문제  (0) 2023.02.07
[알고리즘] 2개 이하로 다른 비트  (0) 2023.02.05
[알고리즘] 피로도 - 다시 풀기  (0) 2023.02.01
[알고리즘] n^2 배열 자르기  (0) 2023.01.30
[알고리즘] 롤케이크 자르기  (0) 2023.01.24
'알고리즘' 카테고리의 다른 글
  • [알고리즘] 콜라 문제
  • [알고리즘] 2개 이하로 다른 비트
  • [알고리즘] 피로도 - 다시 풀기
  • [알고리즘] n^2 배열 자르기
잉여개발자
잉여개발자
풀스택 개발자를 목표로 잉여롭게 개발 공부도 하면서 다양한 취미 생활도 즐기고 있는 잉여 개발자입니다.
  • 잉여개발자
    잉여로운 개발일지
    잉여개발자
    • 분류 전체보기 (789)
      • 개발정보 (36)
      • 개발환경 (7)
      • 개발생활 (19)
      • React (141)
        • 이론 (23)
        • 기능 (12)
        • 실험실 (88)
        • 버그 (6)
        • 패스트캠퍼스 (9)
        • Npm (3)
      • React Native (28)
        • 공통 (6)
        • TypeScript (3)
        • JavaScript (18)
        • 버그 (1)
      • Next.js (30)
        • 이론 (13)
        • 실험실 (13)
        • 버그 (3)
      • Web (35)
      • 알고리즘 (202)
        • 풀이 힌트 (39)
      • JavaScript (47)
      • TypeScript (29)
        • 기초 (27)
        • 실험실 (2)
      • Node.js (13)
        • 이론 (0)
        • 기능 (3)
        • 실험실 (9)
        • 버그 (1)
      • 도커 (4)
      • CCNA (22)
        • 이론 (4)
        • 문제 (18)
      • 취미생활 (167)
        • 잉여로운 칵테일 (2)
        • 잉여의 식물키우기 (130)
        • 잉여로운 여행기 (11)
        • 잉여의 제2외국어 (21)
        • 잉여로운 책장 (2)
      • Java (1)
        • Java의 정석 (1)
      • 꿀팁 공유 (3)
  • 태그

    식물
    네트워크
    덤프
    영어회화
    react
    타일러영어
    Babel
    redux
    Node.js
    알고리즘
    리액트
    자바스크립트
    ChatGPT
    리얼클래스
    다이소
    바질 키우기
    CSS
    javascript
    webpack
    next.js
    네이버 부스트캠프
    리얼학습일기
    타입스크립트
    typescript
    CCNA
    프로그래머스
    영어독학
    Docker
    바질
    ReactNative
  • hELLO· Designed By정상우.v4.10.1
잉여개발자
[알고리즘] 전력망을 둘로 나누기
상단으로

티스토리툴바