[프로그래머스] 도넛과 막대 그래프

2024. 9. 23. 23:43·PS/프로그래머스
반응형

문제

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

입력

edges:[[Int]] = [[출발정점 번호, 도착 정점번호]]

결과

answer [Int] = [중앙정점, 도넛 그래프 개수, 막대 그래프 개수, 8자 그래프 개수]

해석

각 그래프의 특징을 살펴보자.

 

그래프 특징

1. 막대 그래프: 그래프 내에 나가는 간선이 없는 정점이 있다.

2. 8자 그래프: 그래프 내에 들어오는 간선과 나가는 간선이 모두 2개 이상인 정점이 있다.

3. 도넛 그래프: 판단할 큰 특징이 없어 전체 그래프에서 막대그래프와 8자 그래프를 뺀 나머지로 개수를 세준다.

 

(도넛그래프 수 = 전체 그래프 수 -  (막대 그래프 수 + 8자 그래프 수))

 

그래프 특징은 정리가 되었다.

해야할 것을 정리해보자.

 

1. 우리는 나가는 간선과 들어가는 간선의 개수를 카운팅해야한다.

2. 정점간의 연결관계인 그래프를 그린다.

3.  (1<= 정점 번호 <= ?? ) 이므로 최대 정점번호도 구해줘야한다.

4. 여기서 중요한 특징은 정점이 1 ,2,3,4 연속적으로 나온다는 조건이 없으므로 , 존재하지 않는 정점인지 역시 판단해야한다.

코드

import Foundation

func solution(_ edges:[[Int]]) -> [Int] {
    // 중앙 정점이 가르키는 각 그래프 정점 특징
    // n 도넛 = 규칙이 크게 없음, 그냥  막대와 8자를 구하고 나머지를 도넛
    // n 막대 = 나가는 정점 없음 
    // 8자 막대 = 나가는 정점 들어오는 정점 2개 이상
    // 입력 = [[출발 정점, 도착정점]]
    // 결과 = [정점, 도넛, 막대, 8자]
    // 중앙정점 = 들어가는 간선이 없고 나가는 간선이 2이상
    var answer: [Int] = [0, 0, 0, 0]
    var graph: [Int: [Int]] = [:]
    var inDegrees: [Int: Int] = [:]
    var outDegrees: [Int : Int] = [:]
    
    var maxVertex: Int = -1
    
    for edge in edges {
        let departureVertex = edge[0]
        let destinationVertex = edge[1]
        
        maxVertex = max(departureVertex, maxVertex)
        maxVertex = max(destinationVertex, maxVertex)
        
        
        outDegrees[departureVertex, default: 0] += 1
        inDegrees[destinationVertex, default: 0] += 1
        graph[departureVertex, default: []].append(destinationVertex)
        
        
    }

    for v in 1...maxVertex {
    
        let inCount = inDegrees[v, default: 0]
        let outCount = outDegrees[v, default: 0]
        
        // 존재하지 않는 정점
        if inCount == 0 && outCount == 0 { continue }
        
        if inCount == 0 && outCount >= 2 { // 들어가는 간선이 없고 나가는 간선이 2이상이면 중앙 점점
            // 나가는 간선이 2 이상인 이유는 , 그래프 수의 합이 2 이상이기때뮨에
            answer[0] = v 
        } else if inCount >= 2 && outCount >= 2 { // 8자
            // inCount: (정점에서 가르키는 간선 + 8자 가운데 간선)
            // outCount: 8자 가운데에서 나가는 간선
            answer[3] += 1 
        } else if inCount <= 2 && outCount == 0 { // 막대 
            // inCount: (정점에서 가르키는 간선 + 막대 그래프 내에서 가르키는 간선)
            // outCount: 나가는 간선이 없음
            answer[2] += 1 
        }
        
    }
    
    // 도넛그래프 수 = 전체그래프 수 - (막대 + 8자)
    answer[1] = graph[answer[0]]!.count - (answer[2] + answer[3])  

    return answer
}
반응형

'PS > 프로그래머스' 카테고리의 다른 글

[프로그래머스] 광고 삽입  (0) 2024.09.28
[프로그래머스] 합승 택시 요금  (0) 2024.09.27
[프로그래머스] 택배 배달과 수거하기  (0) 2024.09.22
[프로그래머스] 이모티콘 할인행사  (2) 2024.09.21
[프로그래머스] 양궁대회  (2) 2024.09.20
'PS/프로그래머스' 카테고리의 다른 글
  • [프로그래머스] 광고 삽입
  • [프로그래머스] 합승 택시 요금
  • [프로그래머스] 택배 배달과 수거하기
  • [프로그래머스] 이모티콘 할인행사
Hamp
Hamp
남들에게 보여주기 부끄러운 잡다한 글을 적어 나가는 자칭 기술 블로그입니다.
  • Hamp
    Hamp의 분리수거함
    Hamp
  • 전체
    오늘
    어제
    • 분류 전체보기 (339)
      • CS (30)
        • 객체지향 (2)
        • Network (7)
        • OS (6)
        • 자료구조 (1)
        • LiveStreaming (3)
        • 이미지 (1)
        • 잡다한 질문 정리 (0)
        • Hardware (2)
        • 이론 (6)
        • 컴퓨터 그래픽스 (0)
      • Firebase (3)
      • Programing Langauge (41)
        • swift (34)
        • python (6)
        • Kotlin (1)
      • iOS (134)
        • UIKit (37)
        • Combine (1)
        • SwiftUI (34)
        • Framework (7)
        • Swift Concurrency (22)
        • Tuist (6)
        • Setting (11)
        • Modularization (1)
        • Instruments (6)
      • PS (59)
        • 프로그래머스 (24)
        • 백준 (13)
        • LeetCode (19)
        • 알고리즘 (3)
      • Git (18)
        • 명령어 (4)
        • 이론 (2)
        • hooks (1)
        • config (2)
        • action (7)
      • Shell Script (2)
      • Linux (6)
        • 명령어 (5)
      • Spring (21)
        • 어노테이션 (6)
        • 튜토리얼 (14)
      • CI-CD (4)
      • Android (0)
        • Jetpack Compose (0)
      • AI (21)
        • 이론 (10)
        • MCP (1)
        • LangGraph (10)
  • 블로그 메뉴

    • 홈
    • 태그
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    프로그래머스
    IOS
    property
    dfs
    Tuist
    Spring
    dp
    Swift
    투포인터
    백준
    UIKit
    SwiftUI
    CS
    boostcamp
    dispatch
    GIT
    lifecycle
    concurrency
    protocol
    AVFoundation
  • 최근 댓글

  • 최근 글

  • 반응형
  • hELLO· Designed By정상우.v4.10.0
Hamp
[프로그래머스] 도넛과 막대 그래프
상단으로

티스토리툴바