수다닷컴

  • 해외여행
    • 괌
    • 태국
    • 유럽
    • 일본
    • 필리핀
    • 미국
    • 중국
    • 기타여행
    • 싱가폴
  • 건강
    • 다이어트
    • 당뇨
    • 헬스
    • 건강음식
    • 건강기타
  • 컴퓨터
    • 프로그램 개발일반
    • C언어
    • 비주얼베이직
  • 결혼생활
    • 출산/육아
    • 결혼준비
    • 엄마이야기방
  • 일상생활
    • 면접
    • 취업
    • 진로선택
  • 교육
    • 교육일반
    • 아이교육
    • 토익
    • 해외연수
    • 영어
  • 취미생활
    • 음악
    • 자전거
    • 수영
    • 바이크
    • 축구
  • 기타
    • 강아지
    • 제주도여행
    • 국내여행
    • 기타일상
    • 애플
    • 휴대폰관련
  • 프로그램 개발일반
  • C언어
  • 비주얼베이직

자료구조 Floyd알고리즘 질문

마루나

2023.04.01

질문 내용 :
#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 알고리즘만 지나면
초기화된 값이 출력이 되는지 모르겠습니다. ㅠ.ㅠ
*****************************************************************************/

신청하기





COMMENT

댓글을 입력해주세요. 비속어와 욕설은 삼가해주세요.

  • 백합

    왕초보님 // 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
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

수다닷컴 | 여러분과 함께하는 수다토크 커뮤니티 수다닷컴에 오신것을 환영합니다.
사업자등록번호 : 117-07-92748 상호 : 진달래여행사 대표자 : 명현재 서울시 강서구 방화동 890번지 푸르지오 107동 306호
copyright 2011 게시글 삭제 및 기타 문의 : clairacademy@naver.com