[Programmers#49191] 순위

2024. 9. 14. 18:02·Algorithm/문제풀이

❒ Description


레벨 3
제목 순위
링크 https://school.programmers.co.kr/learn/courses/30/lessons/49191
자료구조 그래프
시간복잡도 O(V³)

 

이번 문제는 처음에는 Map과 PriorityQueue로 접근해서 풀어보려고 했다.

하지만 이 문제는 Floyd-Warshall 알고리즘을 응용해서 풀이하는 문제였다.

 

 

 

 

 

❒ 문제 분석


이번 문제의 목적은 선수의 순위를 매기는 것인데, 어떤 선수의 경우에는 정확하게 순위를 매길 수 없다.

그리고 [A, B], [B, C] 이렇게 되어있을 때 A는 B를 이길 수 있고, B는 C를 이길 수 있다. 이것을 바탕으로

A가 C를 이길 수 있다는 해석을 할 수 있다.

 

예시로 주어진 input 값을 그래프화 했다. 4번이 5번을 이길 수 있는지 확인해보자. [4,2], [2,5] 4는 2를 이기고,

2는 5를 이긴다. 이 뜻은 4 또한 5를 이길 수 있는 것이다. 이걸 코드로 구현하면 된다!!

 

 

 

 

 

 

❒ Solution


 

1. 그래프 생성

int[][] graph = new int[n+1][n+1];

 

 

2. 경기 결과 반영

for (int[] result : results) {
    int winner = result[0];
    int loser = result[1];
    graph[winner][loser] = 1;
    graph[loser][winner] = -1;
}

 

 

3. Floyd - Warshall 알고리즘 수행

생각 할 포인트 : [4, 2], [2, 5] > [4,5] 

 

for (int k = 1; k <= n; k++) {
    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= n; j++) {
            if (graph[i][k] == 1 && graph[k][j] == 1) {
                graph[i][j] = 1;
                graph[j][i] = -1;
            }
            if (graph[i][k] == -1 && graph[k][j] == -1) {
                graph[i][j] = -1;
                graph[j][i] = 1;
            }
        }
    }
}

 

 

4. 순서를 매길 수 있는 모든 선수 count

생각 할 포인트 : 출전 선수가 n 명인 경우 각 선수가 참가할 수 있는 최대 경기 수는 n-1
int result = 0;
for (int i = 1; i <= n; i++) {
    int count = 0;
    for (int k : graph.get(i)) {
        if (k == 0) {
           count ++;
        }	
    }
    if (count == n-1) {
        result ++;
    }
}

 

 

 

 

 

 


'Algorithm > 문제풀이' 카테고리의 다른 글

[LeetCode#55] Jump Game  (0) 2024.09.16
[LeetCode#743] Network Delay Time  (0) 2024.09.15
[Programmers] 게임 맵 최단거리  (0) 2024.09.12
[LeetCode#787] Cheapest Flights Within K Stops  (0) 2024.09.10
[LeetCode#207] Course Schedule  (0) 2024.08.30
'Algorithm/문제풀이' 카테고리의 다른 글
  • [LeetCode#55] Jump Game
  • [LeetCode#743] Network Delay Time
  • [Programmers] 게임 맵 최단거리
  • [LeetCode#787] Cheapest Flights Within K Stops
gilbert9172
gilbert9172
gilbert9172 님의 블로그 입니다.
  • gilbert9172
    バックエンド
    gilbert9172
  • 전체
    오늘
    어제
    • All Categories (180)
      • 우테코 7기 (21)
        • 1주차 (8)
        • 2주차 (5)
        • 3주차 (6)
      • Langauge (4)
        • Java (3)
        • Kotlin (1)
      • Back-End (13)
        • SpringBoot (1)
        • Trouble Shooting (0)
        • Setup & Configuration (1)
        • SQL (3)
        • Redis (8)
      • Architecture (6)
        • Multi Module (1)
        • DDD (5)
      • CS (30)
        • Data Structure (6)
        • Operating System (0)
        • Network (12)
        • Database (10)
        • Design Pattern (2)
      • Algorithm (78)
        • 내용 정리 (18)
        • 문제풀이 (60)
      • DevOps (6)
        • AWS (5)
        • Git (1)
      • Front-End (1)
        • Trouble Shooting (1)
      • Project (6)
        • 페이스콕 (6)
      • Book (14)
        • 이벤트 기반 마이크로서비스 구축 (6)
        • 친절한 SQL 튜닝 (5)
        • Spring Batch Docs (3)
  • 블로그 메뉴

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

  • 공지사항

  • 인기 글

  • 태그

    Two-Pointer
    오블완
    binarysearch
    greedy
    sliding-window
    Back-Tracking
    부분단조성
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.2
gilbert9172
[Programmers#49191] 순위
상단으로

티스토리툴바