결과값이 쓰레기값이 나옵니다!!.
샤인
질문 제목 : 행렬식 구하는 프로그램/어려운 포인터포인터를 이용해 2차원 배열을 동적할당하고 이를 여인수를 이용한 재귀함수로 행렬식 구하는 문제질문 내용 : 포인터 인자 전달이 어디가 잘못되었는지 그리고 소행렬을 구하는 함수가 맞는건지 모르겠습니다.
확인하려고 중간중간에 프린트문을 넣어봤는데 어디서 부터 잘못되었는지 모르겠네요.
사소한거라도 지적부탁드립니다 꾸벅~#include stdio.h
#include stdlib.h
//소행렬식 구하는함수
void minor_matrix(int **mij, int si, int sj, int n){
int **m;
int i, j, k, mi=0, mj=0;
m = (int **)malloc((n)*sizeof(int *)); //행 동적할당
for(k=0; kn; k++){ //열 동적할당
m[k] = (int *)malloc((n)*sizeof(int));
}
for(i=0; in; i++){
for(j=0; jn; j++){
if((i!=si) && (j!=sj)){
for(int mi=0; min-1; mi++){
for(int mj=0; mjn-1; mj++){
mij[mi][mj] = m[i][j];
}
}
}
}
}
for(i=0; in; i++){
for(j=0; jn; j++){
printf(%3d, mij[i][j]);
}
printf(\n);
}
printf(\n);
system(pause);
for(k=0; kn ;k++){//동적할당 해제
free(m[k]);
}
free(m);
}int deta(int **aij, int n){ //재귀호출하여 행렬식구하는 함수
int determin, sign;
int **minor;
/*minor = (int **)malloc((n)*sizeof(int *)); //행 동적할당
for(int i=0; in; i++){ //열 동적할당
minor[i] = (int *)malloc((n)*sizeof(int));
}*/
if(n==1){
return **aij;
}
else{
determin=0;
for(int j=0; jn; j++){
sign=1;
minor_matrix(aij, 0, j, n);
if(j%2==1) sign=-1;
determin+= **(aij+j)*sign*deta(minor ,n-1);
printf(aij[0][j] = %d\n, **(aij+j));
printf(determin = %d\n, determin);
system(pause);
}
}
/*for(int k=0; kn ;k++){//동적할당 해제
free(minor[k]);
}
free(minor);*/
return determin;
}int main()
{
int **a;
int nbyn, input_value;
int i, j, d;
printf(차수 입력 : );
scanf(%d, &nbyn);
fflush(stdin);
a = (int **)malloc((nbyn)*sizeof(int *)); //행 동적할당
for(i=0; inbyn; i++){ //열 동적할당
a[i] = (int *)malloc((nbyn)*sizeof(int));
}
for(i=0; inbyn; i++){
for(j=0; jnbyn; j++){
printf([a%d%d] 값을 입력하세요. : , i+1, j+1);
scanf(%d, &input_value);
a[i][j] = input_value;
}
}
printf(%d x %d 행렬\n, nbyn, nbyn);
for(i=0; inbyn; i++){
for(j=0; jnbyn; j++){
printf(%3d, a[i][j]);
}
printf(\n);
}
printf(행렬식 det(a) = );
printf(%d\n, deta(a, nbyn));
system(pause);
for(i=0; inbyn ;i++){ //동적할당 해제
free(a[i]);
}
free(a);
return 0;
}
-
둘빛
결과값이 쓰레기값이 나오는 경우는 대부분 누적을 하는 변수를 초기화를 안 해서 그렇습니다.