힙을 이용한 다익스트라 최단경로 알고리즘..
큰애
질문 제목 : 질문 내용 :
b[k]가 1이면 시작 노드에서 k노드로 가는 경로가 최종 확정된 최단경로, 0이면 아직 탐색중인 경로
dist[k] 가 시작 노드에서 k 노드로 가는 최단경로라고 했을 때,
힙의 이용이 어떻게 되는건지 궁금합니다. 또 다익스트라 기본적인 개념도 ㅡ,.ㅡ; 일부 궁금합니다.
초기값
disk 배열
0 4 2 9999
b 배열
1 0 0 0
루틴을 한번 돌아서
3 노드를 거쳐서 가는 경로를 구하면
disk 배열
0 4 2 7
b 배열
1 0 1 0
이 맞나요? k 노드를 거쳐서 가는 경로를 확인했을때. 시작 노드에서 k 노드로 가는 경로를 확정짓는건가요?그리고 우선순위큐에는 pairint, int나 구조체 형태로 (노드 id, 경로 비용)을 넣고 경로 비용이 최소가 되도록 넣고.
다음 루틴에서는 disk 배열에서 확정되지 않은 숫자 중 제일 작은건 2 노드이기 때문에
2 노드를 거쳐서 가는 경로를 구하면
disk 배열
0 4 2 5
b 배열
1 1 1 0
이 되겠네요.
여기서 또 큐에 (4, 5)를 넣게 되는데
그럼 이 시점에서 큐는
(4, 5) (4, 7)이 있는데 우선순위 조건에 따라 (4, 5)가 먼저 나오겠죠?
그 루틴을 돌고 난 후에는
b 배열이
1 1 1 1이 될테고,
다음에 나오는 (4, 7)은 b 배열을 봤을때 확정된 경로가 이미 있으니까 그냥 패스하고 다음 원소를 뽑아 처리하면 되는건가요?(다음 원소가 있다고 가정했을 때)
다익스트라 알고리즘을 알고 있었다고 생각했었는데, 참 ㅡ,.ㅡ; 힘드네요.
설명이 괜히 어렵게 된거 같은데, 제가 생각하고 있는 것이 맞는지 봐주세요.
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2695091 | txt 파일 입출력 후 2차 배열에 저장하기입니다. (3) | 헛장사 | 2025-05-17 |
2695063 | 수도요금 프로그램좀 짜주세요. | 시내 | 2025-05-17 |
2695033 | 답변좀요ㅠㅠ (1) | 비사벌 | 2025-05-16 |
2695010 | C++의 STL은 왜 굳이 템플릿화 시켜서 라이브러리를 만드나요? (초보수준의 질문..) (2) | 엘보어 | 2025-05-16 |
2694958 | 로직이 변한다는 것에 대해서 궁금합니다. | 튼동 | 2025-05-16 |
2694929 | 열혈강의 25-2 두번째 문제 질문 | 지우개 | 2025-05-15 |
2694900 | dequeue 에서 리턴값 프린트 방법알려주세요 오늘 12시까지 대화방에 있습니다 도와주세요 | 미투리 | 2025-05-15 |
2694854 | 절대값을 구할때 (2) | 그녀는귀여웠다 | 2025-05-15 |
2694827 | 이제 어떻게 공부해야할지 모르겠네요 | 새얀 | 2025-05-14 |
2694778 | 순열 계산요. | 맛조이 | 2025-05-14 |
2694754 | ShowWindow 함수를 이용하려 하는데 질문있습니다. (2) | 파도 | 2025-05-14 |
2694731 | 리눅스 커널의 시작점 질문 | 미르 | 2025-05-13 |
2694702 | 이거 뭐가문제인가요 코드수정좀 (3) | 맑은 | 2025-05-13 |
2694675 | C언어 후위표기를 중위표기로 | 앨런 | 2025-05-13 |
2694646 | 안녕하세요 파일 합치기 함수! (1) | 연블루 | 2025-05-13 |
2694618 | 잘몰라서 설명부탁드립니다. scanf 관련 (3) | 파라 | 2025-05-12 |
2694590 | 이 코드가 뭐하는 코드일까요? #2 | 빵순 | 2025-05-12 |
2694559 | 동적할당으로 배열(2차원열)을 만드는데 있어 그걸 함수화시키는데... (1) | 늘솔길 | 2025-05-12 |
2694532 | 네트워크에 관하여... (4) | 황소자리 | 2025-05-12 |
2694503 | 프로그램 연산 후 바로 종료되는 현상 (6) | Judicious | 2025-05-11 |