힙을 이용한 다익스트라 최단경로 알고리즘..
큰애
질문 제목 : 질문 내용 :
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 배열을 봤을때 확정된 경로가 이미 있으니까 그냥 패스하고 다음 원소를 뽑아 처리하면 되는건가요?(다음 원소가 있다고 가정했을 때)
다익스트라 알고리즘을 알고 있었다고 생각했었는데, 참 ㅡ,.ㅡ; 힘드네요.
설명이 괜히 어렵게 된거 같은데, 제가 생각하고 있는 것이 맞는지 봐주세요.
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2700668 | c언어 질문입니다. 도와주세요~ (3) | 가자 | 2025-07-07 |
2700639 | 한글입력받아서 ㄱㄴㄷ순서대로출력하는법좀 | 두빛나래 | 2025-07-06 |
2700610 | 정말 기초적인 더하기,여백 문제 help | 무슬 | 2025-07-06 |
2700562 | 함수포인터에서요 (7) | 소심한여자 | 2025-07-06 |
2700530 | 전처리문 질문입니다. (1) | 아놀드 | 2025-07-05 |
2700510 | c언어를 어케하면 잘할수 있을까요.. | 연연두 | 2025-07-05 |
2700484 | 두 개가 차이가 뭔지 알려주세요...(소수 찾는 프로그램) (2) | 날위해 | 2025-07-05 |
2700426 | 인터넷 창 띄우는 질문이요 (1) | 정훈 | 2025-07-04 |
2700400 | 원넓이를 계산이요 ㅜㅜ | 천칭자리 | 2025-07-04 |
2700368 | if에 관해서 질문이요... | Orange | 2025-07-04 |
2700339 | 이거 결과값이 왜이런건지.. (4) | 그댸와나 | 2025-07-04 |
2700313 | 파일 읽어서 저장하는데 빈파일일 경우 문재가 발생하네요.. (2) | 크나 | 2025-07-03 |
2700287 | 구조체 동적할당 연습을 하는데 오류가 뜹니다...(해결) (3) | 아련나래 | 2025-07-03 |
2700264 | 문자와 숫자 동시에 입력??? | 글고운 | 2025-07-03 |
2700236 | txt파일로만 쓰고 읽게 하려면 어떻게 해야 하나요..?? (8) | 미국녀 | 2025-07-03 |
2700211 | 전위 연산자 (2) | 어른처럼 | 2025-07-02 |
2700183 | C에서 파일이름을 받고, 그 파일의 사이즈를 출력해줘야하는데 내용이 출력이 안되네요 ;ㅅ; | 피스케스 | 2025-07-02 |
2700150 | 꼭좀 도와주세요ㅠㅠㅠ | 호습다 | 2025-07-02 |
2700095 | 연산문제...질문... | 오빤테앵겨 | 2025-07-01 |
2700070 | while문 , 3의배수 출력하는 프로그램좀 짜주세욤. | 횃불 | 2025-07-01 |