Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | ||||||
2 | 3 | 4 | 5 | 6 | 7 | 8 |
9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 |
23 | 24 | 25 | 26 | 27 | 28 |
Tags
- trie
- bulk update
- 호텔 방 배정
- Spring Boot
- 티스토리 open api
- 트라이
- 보행자 천국
- 알고리즘
- 트라이 #trie #알고리즘
- pycon
- Python
- 프로그래머스
- 티스토리
- Open API
- 카카오 인턴
- 튜플
- 크레인 인형뽑기 게임
- 가사 검색
- 징검다리 건너기
- 불량 사용자
- CleanCode
- jdbc
- Tistory
Archives
- Today
- Total
택시짱의 개발 노트
[프로그래머스] 순위 본문
링크
https://programmers.co.kr/learn/courses/30/lessons/49191
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
풀이
선수의 수 n, 경기 결과를 담은 2차원 배열 results가 매개변수로 주어질 때 정확하게 순위를 매길 수 있는 선수의 수를 구하는 문제이다.
먼저 선수간의 승패로 방향 그래프 2개를 만들 었습니다.
첫 번째 그래프는 내가 이긴 사람으로 향하는 그래프,
두 번재 그래프는 내가 진 사람으로 향하는 그래프,
그리고 문제에서는 선수의 수가 100이하 이기 때문에 그래프에서 최단 거리를 구하는 알고리즘 중에서
o(n^3)에 해당하는 플로이드 워셜을 이용하였습니다.
첫 번째 그래프에 플로이드 워셜을 이용하면 내가 이길수 있는 모든 선수가 구해지게 되고
두 번째 그래프에 플로이드 워셜을 이용하면 내가 질 수 있는 모든 선수가 구해지게 됩니다.
그리고 첫 번째 그래프와 두 번째 그래프를 모두 탐색하여 두개의 그래프중
A -> B 경우 즉 이기거나 지는 경우가 있을 경우에는 A 와 B는 서로 비교를 할 수 있다고 체크하고
A에서 모든 경우에 경로가 있다면 순위를 매길 수 있다고 하였습니다.
#include<iostream>
#include<vector>
#include<algorithm>
#include<queue>
#include<string>
#include<set>
#include<map>
#include<cstring>
#include<cmath>
#define SIZE 110
const int INF = 2e6;
using namespace std;
typedef long long int ll;
int arr[SIZE][SIZE];
void init() {
for (int i = 0; i < SIZE; i++) {
for (int j = 0; j < SIZE; j++) {
if (i == j) continue;
arr[i][j] = INF;
}
}
}
int solution(int n, vector<vector<int>> results) {
init();
for (auto result : results) {
arr[result[0]][result[1]] = 1;
arr[result[1]][result[0]] = 1;
}
int results_size = results.size();
for (int k = 1; k <= n; k++) {
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= n; j++) {
if (i == j) continue;
arr[i][j] = min(arr[i][j], arr[i][k] + arr[k][j]);
}
}
}
int res = 0;
for (int i = 1; i <= n; i++) {
int cnt = 0;
for (int j = 1; j <= n; j++) {
if (i == j) continue;
if (arr[i][j] != INF)
cnt++;
}
res = cnt == n-1 ? res + 1 : res;
}
return res;
}
반응형
'알고리즘' 카테고리의 다른 글
[백준] 4179번 불! (0) | 2020.04.25 |
---|---|
[프로그래머스] 가장 먼 노드 (0) | 2020.04.15 |
[SW Expert] 5521. 상원이의 생일파티 (0) | 2020.04.07 |
[프로그래머스] 구명보트 (0) | 2020.04.07 |
[프로그래머스] 징검다리 건너기 (0) | 2020.04.01 |
Comments