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 | 29 | 30 | 31 |
Tags
- 1563
- 2294
- directx
- 프로그래머스
- baekjoon
- DeferredRendering
- 오블완
- 팰린드롬 만들기
- winapi
- 티스토리챌린지
- algorithm
- UnrealEngine4
- RVO
- UnrealEngine5
- softeer
- 언리얼엔진5
- Frustum
- C++
- IFileDialog
- NRVO
- DirectX11
- Programmers
- const
- 줄 세우기
- 백준
- RootMotion
- GeeksForGeeks
- Unreal Engine5
- C
- UE5
Archives
- Today
- Total
Game Develop
[Algorithm] Programmers :: 순위 본문
https://school.programmers.co.kr/learn/courses/30/lessons/49191
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
29
30
31
32
33
34
35
36
37
38
39
40
41
|
int graph[101][101] = { false };
int solution(int n, vector<vector<int>> results) {
int answer = 0;
for (int i = 0; i < results.size(); ++i)
{
graph[results[i][0]][results[i][1]] = true;
}
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] && graph[k][j])
{
graph[i][j] = true;
}
}
}
}
for (int i = 1; i <= n; ++i)
{
int count = 0;
for (int j = 1; j <= n; ++j)
{
if (graph[i][j] || graph[j][i])
{
++count;
}
}
if (count == n - 1) ++answer;
}
return answer;
}
|
cs |
먼저 플로이드와샬로 풀이한 문제이다.
승패를 전부 일일이 업데이트한 다음, 특정 선수의 승패결과가 n-1개일 경우(확실한 순위를 알 경우)
++answer하는 풀이이다.
다만 이번문제는 정점이 최대 100이라 괜찮지만 정점이 더 많아질수록 효율은 급감한다.
아래 코드는 DFS. 위로 타고가는 그래프와 아래로 타고가는 그래프를 따로 정의해봤다.
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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
|
vector<vector<int>> upGraph(101);
vector<vector<int>> downGraph(101);
bool visited[101];
int upCount = 0;
int downCount = 0;
void upDFS(int n)
{
for (int i = 0; i < upGraph[n].size(); ++i)
{
int next = upGraph[n][i];
if (!visited[next])
{
++upCount;
visited[next] = true;
upDFS(next);
}
}
}
void downDFS(int n)
{
for (int i = 0; i < downGraph[n].size(); ++i)
{
int next = downGraph[n][i];
if (!visited[next])
{
++downCount;
visited[next] = true;
downDFS(next);
}
}
}
int solution(int n, vector<vector<int>> results) {
int answer = 0;
for (int i = 0; i < results.size(); ++i)
{
upGraph[results[i][1]].push_back(results[i][0]);
downGraph[results[i][0]].push_back(results[i][1]);
}
for (int i = 1; i <= n; ++i)
{
upCount = 0;
downCount = 0;
memset(visited, false, sizeof(visited));
visited[i] = true;
upDFS(i);
memset(visited, false, sizeof(visited));
visited[i] = true;
downDFS(i);
if (upCount + downCount == n - 1)
{
++answer;
}
}
return answer;
}
|
cs |
각 정점에 대해 위로타고 가는 그래프, 즉 자신을 이긴 상대와 그 상대를 이긴 상대를 알수있는 탐색을 정의하고
마찬가지로 아래로 타고 가는 그래프를 정의했다.
위로 올라가면서 카운팅한 값과 아래로 타면서 카운팅한 값을 더했을 때, 이 값이 n-1이면 확실히 승패를 알 수 있기때문에 ++answer을 해준다.
성능은 크게 차이는 없지만 정점개수가 100개가 아니라 그 이상이라면 효율은 더 좋을것이다.
'Algorithm > Programmers' 카테고리의 다른 글
[Algorithm] Programmers :: 두 큐 합 같게 만들기 (1) | 2023.02.02 |
---|---|
[Algorithm] Programmers :: 무인도 여행 (0) | 2023.02.02 |
[Algorithm] Programmers :: 등산코스 정하기 (0) | 2023.01.16 |
[Algorithm] Programmers :: 길 찾기 게임 (0) | 2022.10.12 |
[Algorithm] Programmers :: 다단계 칫솔 판매 (0) | 2022.10.08 |