Notice
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- UML관련
- UE_LOG
- 크리티컬섹션
- 강참조
- BFS
- C++최적화
- 선택정렬
- 스마트포인터
- 델리게이트
- C++
- 약참조
- 정렬알고리즘
- 람다사용정렬
- 프로그래머스
- 람다
- 알고리즘
- UE4 커스텀로그
- unorder_map
- dataasset
- map
- 데이터애셋
- enumasByue
- 정렬
- moreeffectiveC++
- 언리얼엔진구조체
- 언리얼가비지컬렉터
- 자료구조
- stl
- UELOG
- 애셋로드
Archives
- Today
- Total
기억을 위한 기록들
[백준 9466: 텀 프로젝트] - C++ 본문
#include<iostream>
using namespace std;
int n = 0;
int cnt = 0;
int arr[100001];
int visited[100001];
int resultArr[100001];
void D(int curNum) {
visited[curNum] = true;
int targetNum = arr[curNum]; //현재노드가 가리키고 있는 번호
if (!visited[targetNum]) //해당 번호를 방문한적 없으면 true
{
D(targetNum);
}
else { //이미 방문해서 확인했으면 현재 번호와 연결되어 있는 노드 세기
if (!resultArr[targetNum]) //이미 노드를 셌다면 패스
{
for (int i = targetNum; i != curNum; i = arr[i]) //연결되있는 번호들 확인
{
cnt++;//연결된 점들 개수 세기
}
cnt++;//자기 자신
}
}
resultArr[curNum] = true;
}
int main()
{
int total;
cin >> total;
for (int index = 0; index < total; index++)
{
memset(arr, 0, sizeof(arr));
memset(visited, 0, sizeof(visited));
memset(resultArr, 0, sizeof(resultArr));
cnt = 0;
cin >> n;
for (int i = 1; i <= n; i++)
{
cin >> arr[i];
}
for (int i = 1; i <= n; i++)
{
if (visited[i] == false)
{
D(i);
}
}
cout << n-cnt << endl;
}
return 0;
}
'Coding Test - cpp > DFS' 카테고리의 다른 글
[백준 1303: 전쟁 - 전투 ] - C++ (0) | 2021.02.25 |
---|---|
[백준 2210: 숫자판 점프] - C++ (0) | 2021.02.18 |
[프로그래머스 lv2] 단어 변환- c++ (0) | 2021.02.16 |
[백준 1937: 욕심쟁이 판다] - C++ (0) | 2021.02.15 |
[백준 2573: 빙산] - C++ (0) | 2021.02.15 |