위와 같은 비상 연락망을 대상으로 DFS의 탐색과정을 보이기 바랍니다. 이때 되돌아오는 과정까지 나열해야 하며 '수정'에서부터 시작하고, '수정'에서 끝나야 합니다. 그리고 연락할 대상이 둘 이상이라면 사전 편찬 순을 기준으로 연락 대상을 결정합니다. 예를 들어서 '동수'의 연락 대상은 '지민'과 '지율'입니다. 이때 '동수'는 지민에게 연락을 취합니다. 제가 작성한 답은 아래의 '더보기'를 클릭하여 확인할 수 있습니다. 더보기 수정, 민석, 지민, 동수, 지율, 동수, 지민, 민석, 정희, 민석, 수정
주의 사항! 이 글은 제가 직접 공부하는 중에 작성되고 있습니다. 따라서 제가 이해하는 그대로의 내용이 포함됩니다. 따라서 이 글은 사실과는 다른 내용이 포함될 수 있습니다. 그래프의 탐색은 그 어떤 자료구조보다도 복잡한 편입니다. 그래프는 정점의 구성뿐만 아니라 간선의 연결에도 규칙이 존재하지 않기 때문입니다. 그래서 그래프의 탐색을 위한, 다시 말해서 그래프의 모든 정점을 돌아다니기 위한 별도의 알고리즘 두 가지를 소개합니다. 깊이 우선 탐색 Depgh First Search(DFS) 너비 우선 탐색 Breadgh First Search(BFS) 우선은 깁이 우선 탐색의 방법을 먼저 설명하겠습니다. 아래의 그래프는 앞서 보였던 비상 연락망입니다. 현재 L 학생에게 비상 메시지가 전달되었습니다. 따라서..
주의 사항! 이 글은 제가 직접 공부하는 중에 작성되고 있습니다. 따라서 제가 이해하는 그대로의 내용이 포함됩니다. 따라서 이 글은 사실과는 다른 내용이 포함될 수 있습니다. 그래프의 구현 관점에서 무방향 그래프와 방향 그래프의 유일한 차이점은 연결 리스트에 추가하는 노드의 수에 있기 때문에, 이 둘의 구현 방법에는 차이가 없다고 볼 수 있습니다. 굳이 따지자면 무방향 그래프를 구현할 때 연결 리스트에 추가해야 하는 노드의 수가 방향 그래프에 비해 두 배 많기 때문에 무방향 그래프의 구현이 좀 더 복잡하다고 할 수 있습니다. 그래서 무방향 그래프를 대상으로 구현해 보고자 합니다. 헤더 파일은 다음과 같습니다. //ALGraph.h //수정 날짜 : 2021.03.27 //작성자 : KOEY #ifndef..
주의 사항! 이 글은 제가 직접 공부하는 중에 작성되고 있습니다. 따라서 제가 이해하는 그대로의 내용이 포함됩니다. 따라서 이 글은 사실과는 다른 내용이 포함될 수 있습니다. 어플을 사용하면 버스와 지하철의 노선도를 확인할 수 있습니다. 그리고 출발지와 목적지를 입력하면, 그에 맞는 최적의 경로를 알 수도 있습니다. 이러한 프로그램의 구현에 사용되는 것이 바로 그래프 알고리즘입니다. 그래프 알고리즘은 수학자 '오일러'에 의해 고안되었습니다. 오일러는 1736년도에 그 유명한 '쾨니히스베르크의 다리 문제'를 풀기 위해서 그래프 이론을 사용했다고 합니다. 쾨니히스베르크의 다리 문제에 대해 조금 찾아보면 흥미로울 것입니다. 다음 그림은 어느 초등학교 5학년 3반 학생들의 비상연락망 구조를 표현한 것입니다. 위..
주의 사항! 이 글은 제가 직접 공부하는 중에 작성되고 있습니다. 따라서 제가 이해하는 그대로의 내용이 포함됩니다. 따라서 이 글은 사실과는 다른 내용이 포함될 수 있습니다. 충돌 문제는 테이블의 핵심 주제라고 할 수 있습니다. 충돌 문제를 해결하는 것이 뭔가 특별할 것 같지만 사실 개념 자체는 간단합니다. 만약 충돌이 발생하면, 충돌이 발생한 그 자리를 대신해서 빈자리를 찾는 것입니다. 그리고 빈자리를 찾는 방법에 따라서 해결책이 구분됩니다. 충돌이 발생했을 때 그 해결방법으로 우선 '선형 조사법'과 '이차 조사법'에 대해 설명하겠습니다. 선형 조사법은 충돌이 발생했을 때 그 옆자리가 비어 있는지 확인하고 빈자리에 데이터를 저장하는 방법입니다. 해쉬 함수가 다음과 같이 정의되어 있고, int HashF..
주의 사항! 이 글은 제가 직접 공부하는 중에 작성되고 있습니다. 따라서 제가 이해하는 그대로의 내용이 포함됩니다. 따라서 이 글은 사실과는 다른 내용이 포함될 수 있습니다. 앞서 소개한 AVL 트리는 탐색과 관련하여 매우 만족스러운 성능을 보였습니다. 하지만 탐색 키의 비교 과정을 거치면서 찾는 대사에 가까워지는 방식이기 때문에, 원하는 바를 '단번에' 찾아내는 방식이라고 말하기는 어렵습니다. 때문에 상황에 따라서는 이러한 AVL 트리의 성능에 만족하지 못할 수도 있습니다. 그리고 이러한 상황에서 도입을 검토할 수 있는 자료구조가 바로 '테이블'입니다. 테이블도 자료구조인데 찾고자 하는 데이터를 '단번에' 찾을 수 있다니 믿기 어려우실 겁니다. 물론 테이블이라고 해서 정말로 찾고자 하는 데이터를 단번에..