Dijkstra의 최단 경로 프로그램에 대해서..
차나
Dijkstra의 최단 경로 프로그램 좀 짜 주세요.소스는 이러하고 비주얼 스튜디오 2008을 쓰는데...프로젝트는 빈 프로젝트를 쓰고 리소스로는 c++을 씁니다. 그런데 안 되네요.#include stdio.h
#include limits.h
#define TRUE 1
#define FALSE 0
#define MAX_VERTICES 7 //정점의 수
#define INF 1000 //무한대(연결이 없는 경우)
int weight[MAX_VERTICES][MAX_VERTICES]={//네트워크의 인접 행렬
{ 0, 7, INF, INF, 3, 10, INF },
{ 7, 0, 4, 10, 2, 6, INF },
{ INF, 4, 0, 2, INF, INF, INF },
{ INF, 10, 2, 0, 11, 9, 4 },
{ 3, 2, INF, 11, 0, INF, 5 },
{ 10, 6, INF, 9, INF, 0, INF },
{ INF, INF, INF, 4, 5, INF, 0 }};
int distance[MAX_VERTICES]; //시작정점으로부터의 최단경로 거리
int found[MAX_VERTICES]; //방문한 정점 표시
int choose(int distance[], int n, int found[])
{
int i, min, minpos;
min = INT_MAX;
minpos = -1;
for(i=0;in;i++)
if( distance[i]min && !found[i] ){
min = distance[i];
minpos=i;
}
return minpos;
}
void shortest_path(int start, int n)
{
int i, u, w;
for(i=0; in; i++) //초기화
{distance[i] = weight[start][i];
found[i] = FALSE;
}
found[start] = TRUE; //시작 정점 방문 표시
distance[start] =0;
for(i=0; in-2; i++){
u = choose(distance, n, found);
found[u] = TRUE;
for(w=0; wn; w++)
if(!found[w])
if( distance[u]+weight[u][w]distance[w] )
distance[w] = distance[u]+weight[u][w];
}
}
void main()
{
int start, i;
printf(start 정점을 입력하십시오 : );
scanf(%d, &start);//오류 부분
shortest_path(start, MAX_VERTICES);
for(i = 0; iMAX_VERTICES; i++) {
if (i == start) countinue;//오류 부분
printf( %d 부터 %d 까지의 최단거리는 %d 입니다.\n, start, i, distance[i]);
}
}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
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 |
2700041 | 초보인데요 ㅎ 배열안에 배열을 집어넣을수 있나요?? | 헛장사 | 2025-07-01 |
2700012 | 배열// (1) | 전갈자리 | 2025-07-01 |
2699895 | 무한루프에 빠집니다.!! 해결좀부탁드려요 (10) | 선아 | 2025-06-30 |