병렬 검색 알고리즘
검색은 컴퓨터 과학의 기본 작업 중 하나입니다. 요소가 주어진 목록에 있는지 여부를 찾아야하는 모든 응용 프로그램에서 사용됩니다. 이 장에서는 다음 검색 알고리즘에 대해 설명합니다.
- 분할 및 정복
- 깊이 우선 검색
- 폭 우선 검색
- 최우선 검색
분할 및 정복
분할 및 정복 접근법에서 문제는 몇 가지 작은 하위 문제로 나뉩니다. 그런 다음 하위 문제를 재귀 적으로 해결하고 결합하여 원래 문제의 솔루션을 얻습니다.
분할 및 정복 접근법은 각 수준에서 다음 단계를 포함합니다.
Divide − 원래 문제는 하위 문제로 나뉩니다.
Conquer − 하위 문제는 재귀 적으로 해결됩니다.
Combine − 하위 문제의 해를 결합하여 원래 문제의 해를 구합니다.
이진 검색은 분할 및 정복 알고리즘의 예입니다.
의사 코드
Binarysearch(a, b, low, high)
if low < high then
return NOT FOUND
else
mid ← (low+high) / 2
if b = key(mid) then
return key(mid)
else if b < key(mid) then
return BinarySearch(a, b, low, mid−1)
else
return BinarySearch(a, b, mid+1, high)
깊이 우선 검색
깊이 우선 검색 (또는 DFS)은 트리 또는 무 방향 그래프 데이터 구조를 검색하기위한 알고리즘입니다. 여기에서 개념은 시작 노드에서 시작하는 것입니다.root같은 지점에서 가능한 한 멀리 횡단합니다. 후속 노드가없는 노드를 얻으면 아직 방문하지 않은 정점으로 돌아가 계속합니다.
깊이 우선 검색 단계
이전에 방문하지 않은 노드 (루트)를 고려하고 방문한 것으로 표시하십시오.
첫 번째 인접 후속 노드를 방문하여 방문한 것으로 표시합니다.
고려 된 노드의 모든 후속 노드가 이미 방문되었거나 더 이상 후속 노드가없는 경우 상위 노드로 돌아갑니다.
의사 코드
허락하다 v 그래프에서 검색이 시작되는 꼭지점 G.
DFS(G,v)
Stack S := {};
for each vertex u, set visited[u] := false;
push S, v;
while (S is not empty) do
u := pop S;
if (not visited[u]) then
visited[u] := true;
for each unvisited neighbour w of u
push S, w;
end if
end while
END DFS()
폭 우선 검색
BFS (Breadth-First Search)는 트리 또는 무 방향 그래프 데이터 구조를 검색하는 알고리즘입니다. 여기서는 노드로 시작한 다음 동일한 수준의 모든 인접 노드를 방문한 다음 다음 수준의 인접한 후속 노드로 이동합니다. 이것은 또한 알려진level-by-level search.
폭 우선 검색의 단계
- 루트 노드로 시작하여 방문한 것으로 표시하십시오.
- 루트 노드에는 같은 수준의 노드가 없으므로 다음 수준으로 이동합니다.
- 인접한 모든 노드를 방문하고 방문한 것으로 표시하십시오.
- 다음 레벨로 이동하여 방문하지 않은 모든 인접 노드를 방문하십시오.
- 모든 노드를 방문 할 때까지이 프로세스를 계속하십시오.
의사 코드
허락하다 v 그래프에서 검색이 시작되는 꼭지점 G.
BFS(G,v)
Queue Q := {};
for each vertex u, set visited[u] := false;
insert Q, v;
while (Q is not empty) do
u := delete Q;
if (not visited[u]) then
visited[u] := true;
for each unvisited neighbor w of u
insert Q, w;
end if
end while
END BFS()
최우선 검색
Best-First Search는 가능한 최단 경로에서 목표에 도달하기 위해 그래프를 순회하는 알고리즘입니다. BFS 및 DFS와 달리 Best-First Search는 평가 기능을 따라 다음에 순회하기에 가장 적합한 노드를 결정합니다.
Best-First Search 단계
- 루트 노드로 시작하여 방문한 것으로 표시하십시오.
- 다음 적절한 노드를 찾아 방문한 것으로 표시하십시오.
- 다음 레벨로 이동하여 적절한 노드를 찾아 방문한 것으로 표시하십시오.
- 목표에 도달 할 때까지이 프로세스를 계속하십시오.
의사 코드
BFS( m )
Insert( m.StartNode )
Until PriorityQueue is empty
c ← PriorityQueue.DeleteMin
If c is the goal
Exit
Else
Foreach neighbor n of c
If n "Unvisited"
Mark n "Visited"
Insert( n )
Mark c "Examined"
End procedure