동적할당 이용 배열선언 질문입니다.ㅠㅠ
크나
printf(매트릭스 크기를 입력하세요!\n); // 행렬의 크기 지정
scanf(%d,&n);
y_bus=(double **) malloc(n*n*sizeof(double));
y_admittance=(double **) malloc(n*n*sizeof(double));
for(i=0;in;i++)// 배열 초기화
{
for(j=0;jn;j++)
{
y_bus[i][j]=0;
y_admittance[i][j]=0;
}
}
for(i=0;in;i++) // admittance matrix 만들기
{
for(j=0;jn;j++)
{
printf(from %d to %d 의 admittance를 입력하세요.\n, i+1,j+1);
scanf(%lf,&y_admittance[i][j]);
}
}
이렇게 하면 배열 초기화시 에러가 납니다.ㅠㅠ
초기화 부분을 지우면 matrix입력 받을때 에러가 나구요...
아무래도 생성된 동적할당 배열에 접근을 못하는 것 같은데;;
어떻게 해결하면 좋을까요?ㅠㅠ
-
로지
y_bus=(double **) malloc(n*n*sizeof(double));
y_admittance=(double **) malloc(n*n*sizeof(double));
동적 할당에서 포인터 개념을 이해하는 것은 중요합니다 포인터는 *으로 표시되는데 *는 다른 공간에 메모리가 얼마만큼인지 모르지만 공간을 만들어서 그 첫번째 주소만을 저장한다
*(포인터)는 절대로 크기를 알수 없습니다 어느 곳에 만들어 질지 어느 주소에 저장 될지는 모름니다 -
연보라
아하~! 인클루드님 말씀은
a[0][0] a[0][1] ... a[0][n] a[1][0] ...
이런식으로 개념은 2차원이고 1차원 형태로 나타나야 한다는 뜻이지요?^^
설명 감사합니다!! -
아잉누님
인터넷에서 보고 대충 감이 와서 적습니다. 이차원배열이니까 더블포인터는 맞지만 n*n이 아니고 n개의 열을 n개의 행만큼 만들어 주는 것이니까 malloc(n*sizeof(double*))이렇게 되는게 맞는것 같습니다.
뒤에 왜 double*인지는 아마 아시겠지만 모르신다면 설명해 드리겠습니다. 2차원배열을 구체적으로 보면 사각형을 면적단위로 나눈게 아니고 각 행의 배열의 시작점 즉 포인터를 열의 인덱스들이 가지고 있는 형태이기 때문입니다. 개념을 쉽