자료구조 Floyd알고리즘 질문
마루나
질문 내용 :
#include stdio.h
#include limits.h
#include stdlib.h
#include memory.h
typedef struct graph{
int no1;
int no2;
int dis;
}graph;
void floyd(int n, int cnt)
{
FILE *fp;
int **A, **weight;
int i, j, k;
graph temp;
fp = fopen(data.txt, r);
if(fp == NULL){
printf(파일 개방 실패!!!\n);
return;
}
weight = (int**)malloc(n * sizeof(*weight)); //2차원 배열 동적 할당
for(i = 0; i n; i++){
weight[i] = (int*)malloc(n * sizeof(**weight));
}
A = (int**)malloc(n * sizeof(*A)); //2차원 배열 동적 할당
for(i = 0; i n; i++){
A[i] = (int*)malloc(n * sizeof(**A));
}
for(i = 0; i n; i++){ //0으로 초기화
for(j = 0; j n; j++){
A[i][j] = 0;
weight[i][j] = 0;
}
}
for(i = 0; i cnt; i++){ //입력 부분
fscanf(fp, %d%d%d, &temp.no1, &temp.no2, &temp.dis);
weight[temp.no1][temp.no2] = temp.dis;
}
rewind(fp);
for(i = 0; i n; i++){ //배열 출력 부분
for(j = 0; j n; j++){
printf(%-4d, weight[i][j]);
}
printf(\n);
}
for(i = 0; i n; i++){ //A배열에 weight 배열을 덮어 씌움
for(j = 0; j n; j++){
A[i][j] = weight[i][j];
}
}
//
printf(\n\n); //확인
for(i = 0; i n; i++){
for(j = 0; j n; j++){
printf(%-4d, A[i][j]);
}
printf(\n);
}
//
for(k = 0; k n; k++){
for(i = 0; i n; i++){
for(j = 0; j n; j++){
if(A[i][k] + A[k][j] A[i][j]){
A[i][j] = A[i][k] + A[k][j];
}
}
}
}printf(\n\n); //확인
for(i = 0; i n; i++){
for(j = 0; j n; j++){
printf(%-4d, A[i][j]);
}
printf(\n);
}
printf(\n);
for(i = 0; i n; i++){ //메모리 동적할당 해제
free(weight[i]);
free(A[i]);
}
free(weight);
free(A);//여기까지
fclose(fp);
}
int main()
{
FILE *fp;
int max = 0;
graph temp;
int cnt = 0;
int i = 0, j = 0;
fp = fopen(data.txt, r);
if(fp == NULL){
printf(파일 개방 실패!!!\n);
return 0;
}
while(!feof(fp)){ //갯수 파악 및 최고 vertex 파악
fscanf(fp, %d%d%d, &temp.no1, &temp.no2, &temp.dis);
cnt++;
if(max temp.no1){
max = temp.no1;
}
if(max temp.no2){
max = temp.no2;
}
}
rewind(fp);
max += 1;
floyd(max, cnt);
fclose(fp);
return 0;
}/*************************************************************************
위에 빨갛게 해놓은 부분이 문제인데....
메인함수는 문서를 읽어들어 거기에 저장된 vertex의 최대값을 알아내고
기록되어있는 자료가 몇갠지 갯수를 파악하고 함수를 호출하고...
함수로 들어가면 다시 파일을 오픈하고 넘겨받은 매개인자 값으로 메모리를 동적할당합니다.
2차원 배열루요 그리고 weight 배열에 오픈한 파일에 들어있는 값을 집어 넣습니다.(파란색)
메모장에는 0 1 12 // 0 2 21이런 식으로 저장되어 있구요 //는 구분하기 위해 제가 임의로 한거고
그냥 엔터로 구분되어 있습니다. 앞에 숫자 2개는 vertex 넘버구요... 3번째 값은 앞의 2개 vertex에
대한 값입니다. 즉 0 1의 값은 12이고 0 2의 값은 21이 됩니다. 0에서 1로 가는데는 12만큼의 거리이고
0에서 2로 가는데는 21만큼의 거리입니다.
그리고 밑에 출력은 제대로 입력이 되어 있는지 확인하기 위해 출력해 보는 것이고
그 바로 아래에는 weight배열에 입력되어 있는 값을 A배열에 복사합니다.
그리고 A배열에 제대로 복사 되었는지 다시 확인...
그리고 빨간색 부분인 floyd 알고리즘인데... 책 보고 그대로 타이핑한거고 다른 문제에서는
제대로 됐는데 이 문제에서는 안되네요... 아무튼 floyd 알고리즘을 지나고 나면 배열 A가
0으로 초기화 되버립니다.
배열 A에는 분명히 weight배열이 복사되었는데... 어째서 floyd 알고리즘만 지나면
초기화된 값이 출력이 되는지 모르겠습니다. ㅠ.ㅠ
*****************************************************************************/
-
백합
왕초보님 // floyd 함수 내에서 입력 및 출력을 모두 하는데... 포인터 위치가 잘못 될수도 있나요? 제가 포인터 개념을 아직 정확히 못 잡아서... ㅠ.ㅠ 함수가 리턴된다 하심은 floyd함수가 리턴되는걸 말씀하시는건지..?만약 그렇다면 floyd함수가 리턴되기 전에 출력까지 모두 하는건데... 포인터위치가 잘못 될수도 있는건가요?
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
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 |
2699842 | 질문을 너무 많이 하네여.....죄송.... (2) | 해님꽃 | 2025-06-29 |
2699816 | 오류 질문입니다.. (1) | 해비치 | 2025-06-29 |