힙을 이용한 다익스트라 최단경로 알고리즘..
큰애
질문 제목 : 질문 내용 :
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 배열을 봤을때 확정된 경로가 이미 있으니까 그냥 패스하고 다음 원소를 뽑아 처리하면 되는건가요?(다음 원소가 있다고 가정했을 때)
다익스트라 알고리즘을 알고 있었다고 생각했었는데, 참 ㅡ,.ㅡ; 힘드네요.
설명이 괜히 어렵게 된거 같은데, 제가 생각하고 있는 것이 맞는지 봐주세요.
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2694420 | C언어 질문할게요(유니코드,자료형,버퍼,캐스트연산자) | 은새 | 2025-05-11 |
2694370 | 내일까진데 함수호출 제발 도와주세요!!!!!!!!!11 | 들찬 | 2025-05-10 |
2694339 | putchar()의 괄호 안에 int c=10;로 전에 선언된 c를 넣으면 안되는 이유에서 제가 생각한 것이 그 이유가 되는지 확인하고 싶습니다. (3) | 미르 | 2025-05-10 |
2694316 | 이 코드 어디가 잘못되었는지 고수분들 ㅠㅠ (2) | 나빛 | 2025-05-10 |
2694285 | 언어 공부하는 과정 좀 추천해주세요! (1) | 아빠몬 | 2025-05-09 |
2694258 | 카운터.. 질문입니다. (4) | 하늘빛눈망울 | 2025-05-09 |
2694229 | 단순한 질문이요 (8) | 여름 | 2025-05-09 |
2694202 | 용돈을 가지고 할 수 있는 일을 여러가지로 출력하는 방법 좀 알려주세요! (2) | 미나 | 2025-05-09 |
2694145 | 화면깜빡임을 없애고 싶은데요... (1) | 어서와 | 2025-05-08 |
2694069 | unsigned 질문입니다. | 힘차 | 2025-05-07 |
2694012 | 전공 비전공자 개발자 (10) | 말글 | 2025-05-07 |
2693984 | 오버로딩이 무엇인가요? (2) | 헛매질 | 2025-05-07 |
2693956 | PlaySound재생이 안됩니다!(C에 음악넣기) | 지존 | 2025-05-06 |
2693928 | &와 *의 사용에 관한 명확한 이해 | 제나 | 2025-05-06 |
2693903 | 반복문 설명좀요 ㅠㅠ (2) | 란새 | 2025-05-06 |
2693869 | stdio.h 는 왜 쓰는건가요? (1) | 큰꽃들 | 2025-05-06 |
2693842 | 포인터 변수의 주소값끼리 더하는 것에 대해서 질문드립니다. (1) | 진솔 | 2025-05-05 |
2693811 | 소수 출력;;;; | 화이트캣 | 2025-05-05 |
2693788 | 이런 함수는 없나요? (3) | 앤드류 | 2025-05-05 |
2693758 | txt파일 불러와서 행렬로 저장 | 큰애 | 2025-05-05 |