친구들과 함께 행렬 연산 프로그램을 만들고 있는데요
이송이
질문 제목 : 프로그램 오류를 수정해주세요..
컴파일하면 밑의 사진처럼 에러가 뜨는데 도대체 무슨에러인지 모르겠습니다.
고수님들 수정좀 부탁드려요.. ㅠㅠ
밑에 소스 있습니다.질문 내용 :
proj3_def.h
#ifndef proj3_def_h_
#define proj3_def_h_
typedef struct
{
int n; /*행값*/
int m; /*열값*/
double** mat; /* 행렬의 요소값 */
} matrix; /* 행열을 정의하는 매트릭스 */
proj3_io.c
#include stdio.h
#include stdlib.h
#include proj3_def.h
void read_mat_data(const char* strfilename, matrix* m);
void write_mat_data(const char* strfilename, matrix* m);
extern int m,n;
void read_mat_data(const char* strfilename, matrix* m)
{
file *ofp;
int i,j;
ofp = fopen(strfilename, r);
if(ofp==null)
{
printf(파일을 열 수 없습니다.\n);
exit(1);
}
printf(파일이 열렸습니다!\n);
for(i=0; im-n; i++)
span st{
for(j=0;jm-m;j++)
{
fscanf(ofp, %lf, &m-mat[i][j]);
}
}
fclose (ofp);
}
void write_mat_data(const char* strfilename, matrix* m)
{
file *fp;
int i,j;
fp= fopen(strfilename,w);
if(fp==null)
{
printf(파일을 열 수 없습니다.\n);
exit(1);
}
printf(파일이 열렸습니다!\n);
for(i=0; im-n; i++)
{
for(j=0;jm-m;j++)
{
fprintf(fp,%lf\t,&m-mat[i][j]);
}
}fclose(fp);
}proj3_mem.c
void init_mat(matrix* m);
void create_mat(matrix* m, int n, int m);/* 2차원 메모리 할당 하는 함수 */
void delete_mat(matrix* m);
void init_mat(matrix* m)
{
int i,j;
for(i=0;i4;i++)
{
for(j=0;j4;j++)
{
m[i][j]=0;
}
}
}
void create_mat(matrix* m, int n, int m)
{
void** m;
int i;
m = (void**)malloc(n*sizeof(void*));
m[0] = malloc(n*m);
for(i=1;in;i++)m[i] = (void*)((char*)m[0]+m*m*i);
}
void delete_mat(matrix* m)
{
free(m[0]);
free(m);
}
proj3_mat.c#include stdio.h
#include stdlib.h
void mat_sum(matrix* c, matrix* a, matrix* b); /*a+b = c*/
void mat_diff(matrix* c, matrix* a, matrix* b); /*a-b = c*/
void mat_mul(matrix* c, matrix* a, matrix* b); /*a*b = c*/
void mat_sum(matrix* c, matrix* a, matrix* b)
{
int i, j,l,g;
printf(합은 :\n);
for(l=0;l4;l++)/*c배열을 초기화 시킨뒤에 */
{
for(g=0;g4;g++)
{
c[l][g]=0;
}
}
for(i=0;i4;i++)
{
for(j=0;j4;j++)
{
c[i][j] = a[i][j] + b[i][j];/*c행렬을 구한다 c행열은 a,b행렬의 덧셈이다*/
printf(c[%d][%d] :%lf,i,j,c[i][j]);
if(j==1)/*옆에 조건을 만족하면 한칸 띈다*/
{printf(\n);}}
}
printf(\n);
return;
}
void mat_diff(matrix* c, matrix* a, matrix* b)
{
int i,j,l,g;
printf(차는 :\n);
for(l=0;l4;l++)/*행렬 c를 초기화 시킨뒤*/
{
for(g=0;g4;g++)
{
c[l][g]=0;
}
}
for(i=0;i4;i++)
{
for(j=0;j4;j++)
{
c[i][j]=a[i][j]-b[i][j];/*행렬의 뺄셈을 한다*/
printf(c[%d][%d] :%lf ,i,j,c[i][j]);
if(j==1)
{printf(\n);}}
}
printf(\n);
return;
}
void mat_mul(matrix* c, matrix* a, matrix* b)
{
int i,j,k,m,n,l,g;
printf(곱은 :\n);
for(l=0;l4;l++)/*행렬을 초기화시킨다*/
{
for(g=0;g4;g++)
{
c[l][g]=0;
}
}
for(i=0;i4;i++)
{
for(j=0;j4;j++)
{
for(k=0;k4;k++)
{
c[i][j]+=a[i][k]*b[k][j];/*행렬의 곱을 만든다*/}
}
}
for(m=0;m4;m++)
{
for(n=0;n4;n++)
{
printf(c[%d][%d] :%lf,m,n,c[m][n]);/*행렬을 출력한다*/
if(n==1)
{printf(\n);} //zz;;
}
}
printf(\n);
return;
}
proj3_print.cvoid print_matrix(matrix* m);
void print_matrix(matrix* m)
{
printf(matlix 4 by 4);
int i,j;
for(i=0;i4;i++)
{
for(j=0;j4;j++)
{
printf(%lf,m[i][j]);
(j==4)? printf(\n):printf(\t);
}
}
}proj3main.cpp#include proj3_def.h
extern void read_mat_data(const char* strfilename, matrix* m);
extern void write_mat_data(const char* strfilename, matrix* m);
extern void mat_sum(matrix* c, matrix* a, matrix* b); /*a+b = c*/
extern void mat_diff(matrix* c, matrix* a, matrix* b); /*a-b = c*/
extern void mat_mul(matrix* c, matrix* a, matrix* b); /*a*b = c*/
extern void print_matrix(matrix* m);
extern void init_mat(matrix* m);
extern void create_mat(matrix* m, int n, int m);/* 2차원 메모리 할당 하는 함수 */
extern void delete_mat(matrix* m);
int main()
{
puts(1);
return 0;
}
-
이루리
그나저나 4 는 그대로 두실 것 아니죠?
-
텃골
rebuild 해보세요.
proj3main에서 struct MATRIX 가 사용되었다는데, 소스에는 없네요.