Dfs 함수의 순방향 간선 예외 체크 로직에 대해 여쭤봅니다.
456
작성한 질문수 10
Dfs 함수에서
if(_discoveredOrder[here] < _discoveredOrder[there]) contiue;
해당 로직을 통해서 순방향 간선이면 continue를 하여 넘어갔는데 해당 if 문에 걸리는 경우가 존재하나요??
_discoveredOrder[there]의 값이 -1이 아니라는 뜻은 자신의 부모로부터 이미 방문한 적이 있다는 뜻인데 if 문에 걸리는 것이 없는 것 같아서요.
어떤 경우에 발생하는 지 궁금합니다.
답변 2
0
1년 지난 질문이지만 제가 답변해보겠습니다.
순방향 간선의 존재는 그래프를 그려보면 어렵지 않게 찾을 수 있긴 해요. DFS 스패닝 트리가 만들어졌을 때 0 -> 1 -> 5 경로가 트리 간선일 경우, 0 -> 5가 존재하는 간선이 순방향 간선이에요. 즉 순방향 간선은 트리 간선에 포함되지 않는 간선입니다.
순방향 간선은 조상에서 자손으로 가는 일종의 지름길 역할을 하기 때문에, 이미 방문한 노드 간에 발생합니다. 때문에 _discoveredOrder[there]가 != -1인 경우에 생겨요. _discoveredOrder[there]가 == -1인 경우는 트리 간선이에요.
트리 간선(dfs 스패닝 트리), 순방향 간선, 역방향 간선, 교차 간선에 대해 다시 한 번 개념을 잡아보세요🙂
0
안녕하세요, 인프런 AI 인턴이에요.
if(_discoveredOrder[here] < _discoveredOrder[there]) continue; 해당 로직은 DFS(Depth-First Search) 알고리즘에서 순방향 간선을 처리하기 위한 예외 체크 로직입니다.
여기서 _discoveredOrder[here]는 현재 정점(here)의 방문 순서, _discoveredOrder[there]는 순방향 간선으로 연결된 정점(there)의 방문 순서를 나타냅니다.
_discoveredOrder 배열은 초기 값이 -1로 설정되어 있으면서, 각 정점이 방문되는 순서대로 값이 갱신됩니다. 따라서 _discoveredOrder[there] 값이 -1이 아니라는 것은 정점 there이 이미 방문되었다는 의미입니다.
순방향 간선은 정점 here에서 정점 there으로 이어지는 간선이지만, 정점 there이 이미 방문된 상태라면 이 간선은 순환 구조를 형성하게 되며, 따라서 이 간선은 무시해야 합니다. 그래서 if(_discoveredOrder[here] < _discoveredOrder[there]) continue; 코드에서는 이러한 순환 구조를 방지하기 위해 continue 문을 사용하여 다음 간선으로 넘어가도록 처리하고 있습니다.
따라서, 순방향 간선인데 해당 if 문에 걸리는 경우는 발생하지 않으며, 이 경우에는 continue 문을 실행하지 않습니다.
더 자세한 내용이나 다른 질문이 있다면 언제든지 물어보세요. 좋은 하루 되세요!
writeLock을 잡을때 꼭 empty 상태여야하는 이유?
0
32
2
Memory Pool에서 오버플로우 질문입니다.
0
71
2
포토폴리오 및 진로 관련하여 고민입니다.
0
126
1
포토폴리오 관련 고민입니다.
0
65
1
실무에서도 alloc, 스마트포인터 등을 구현해서 쓰는지 궁금합니다.
0
85
2
성능 테스트 결과
0
105
2
게임 서버 Stateful, Stateless 진로 고민
0
128
1
WaitOnAddress와 Sleep의 차이 질문
0
84
1
궁금한거 있습니다.
0
84
2
JobTimer 구동 스레드
0
108
2
TryPop() 동작 관련 질문
0
81
1
로드맵 C#서버 C++서버 방향성 질문
0
151
2
스레드 id를 출력할떄 메인스레드 id도 출력되나요?
0
73
1
생명주기를 위한 의도적 복사
0
87
2
락프리의 실무에서 사용 질문
0
144
2
32bit threadID와 16비트 상위 WriteFlag에 대해
0
103
2
mutex와 sleep 차이점
0
119
1
실무에서는 어떠한 코드 스타일을 사용하는지 궁금합니다
0
156
2
Stomp Allocator의 Release함수에 대한 질문입니다.
0
97
1
공부법 관련해서
0
184
2
MakeShared 함수 관련
0
114
1
지금까지 서버코어에서 만든 내용에 대해 궁금한 점이 있어서 질문 드립니다.
0
145
2
운영체제관련 질문입니다
0
132
1
send하려는 데이터 크기가 크면 memcpy에서 문제가 발생할 것 같습니다.
0
119
2





