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
- 팰린드롬 만들기
- GeeksForGeeks
- 1563
- winapi
- RootMotion
- algorithm
- 줄 세우기
- Unreal Engine5
- DeferredRendering
- C++
- Frustum
- UnrealEngine4
- UnrealEngine5
- RVO
- directx
- 언리얼엔진5
- NRVO
- const
- 2294
- UE5
- baekjoon
- C
- Programmers
- 티스토리챌린지
- 프로그래머스
- DirectX11
- IFileDialog
- softeer
- 백준
- 오블완
Archives
- Today
- Total
Game Develop
[Algorithm]Baekjoon 2162번 : 선분 그룹 본문
https://www.acmicpc.net/problem/2162
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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
|
using namespace std;
typedef pair<int, int> vector2D;
typedef pair<int, int> point;
typedef pair<point, point> lineSegment;
int n, a, b, c, d;
vector<lineSegment> lineSegments;
int parents[3000] = { 0 };
int groupSizes[3000] = { 0 };
int FindParent(int node)
{
if (parents[node] == node) return node;
return parents[node] = FindParent(parents[node]);
}
bool CompareParents(int a, int b)
{
a = FindParent(a);
b = FindParent(b);
if (a == b) return true;
return false;
}
void UnionParents(int a, int b)
{
a = FindParent(a);
b = FindParent(b);
if (a < b)
{
parents[b] = a;
groupSizes[a] += groupSizes[b];
groupSizes[b] = 0;
}
else
{
parents[a] = b;
groupSizes[b] += groupSizes[a];
groupSizes[a] = 0;
}
}
int CCW(point& s1, point& p1, point& p2)
{
vector2D v1 = { p1.first - s1.first, p1.second - s1.second };
vector2D v2 = { p2.first - s1.first, p2.second - s1.second };
long long crossResult = (long long)v1.first * v2.second - (long long)v1.second * v2.first;
if (crossResult < 0) return 1;
else if (crossResult > 0) return -1;
return 0;
}
bool Compare(point& p1, point& p2)
{
if (p1.first == p2.first)
{
return p1.second <= p2.second;
}
return p1.first <= p2.first;
}
void Swap(point& p1, point& p2)
{
point temp = p1;
p1 = p2;
p2 = temp;
}
bool IsIntersection(lineSegment& l1, lineSegment& l2) // 두 선분이 교차하는지 검사.
{
int ccwResult1 = CCW(l1.first, l2.first, l2.second) * CCW(l1.second, l2.first, l2.second);
int ccwResult2 = CCW(l2.first, l1.first, l1.second) * CCW(l2.second, l1.first, l1.second);
if (ccwResult1 == 0 && ccwResult2 == 0) // 둘 다 0이면 두 선분이 일단 한 직선위에 존재한다는 것.
{
if (Compare(l1.first, l1.second) == false)
{
swap(l1.first, l1.second);
}
if (Compare(l2.first, l2.second) == false)
{
swap(l2.first, l2.second);
}
return Compare(l2.first, l1.second) && Compare(l1.first, l2.second);
}
return ccwResult1 <= 0 && ccwResult2 <= 0;
}
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
cin >> n;
for (int i = 0; i < n; ++i)
{
cin >> a >> b >> c >> d;
lineSegments.push_back({ { a,b }, { c,d } });
groupSizes[i] = 1;
parents[i] = i;
}
for (int i = 0; i < n; ++i)
{
for (int j = i + 1; j < n; ++j)
{
lineSegment& a = lineSegments[i];
lineSegment& b = lineSegments[j];
if (IsIntersection(a, b)) // 이어져있고
{
if (CompareParents(i, j) == false) // 아직 집합에 안 합쳤으면
{
UnionParents(i, j); // 합친다.
}
}
}
}
int groupCount = 0;
int maxGroupSize = 0;
for (int i = 0; i < n; ++i)
{
if (groupSizes[i] > 0) ++groupCount;
maxGroupSize = max(maxGroupSize, groupSizes[i]);
}
cout << groupCount << endl << maxGroupSize;
}
|
cs |
이전에 풀었던 선분 교차 2에 Union-Find를 결합한 문제이다. 연결된 선분의 그룹의 개수와 최대 그룹의 크기를 구하는 문제이기 때문에 Union-Find를 사용했다. 선분교차에 대한에 특이사항이 추가된건 없기 때문에 그대로 사용하면 된다.
'Algorithm > Baekjoon' 카테고리의 다른 글
[Algorithm]Baekjoon 2342번 : Dance Dance Revolution (0) | 2024.02.13 |
---|---|
[Algorithm]Baekjoon 2252번 : 줄 세우기 (0) | 2024.02.12 |
[Algorithm]Baekjoon 17387번 : 선분 교차 2 (0) | 2024.02.11 |
[Algorithm]Baekjoon 17386번 : 선분 교차 1 (1) | 2024.02.10 |
[Algorithm]Baekjoon 2143번 : 두 배열의 합 (2) | 2024.02.04 |