가우스 조단 소거법인데요ㅜㅜㅜ
횃불
질문 요약 :가우스-조단 소거법에서 좀 더 큰 행렬을 받고 싶어요.
질문 내용 : 가우스-조단 소거법으로 REF랑 RREF를 만드는데요.
행렬이 4*4를 벗어난 큰 행렬은 값이 아예 안나오거든요.
다른 5*5 라든지 더 큰 행렬의 REF와 RREF가 나오게 하려면 여기서 어떻게 손을 봐야할까요??
머리가 안 돌아가네요ㅜㅜ 도와주세요ㅜㅜㅜㅜ#include stdio.h
#include stdlib.h
#include math.h
#define MAX 5
typedef struct matrix_t
{
int m, n;
double **a;
} matrix_t;
void create(matrix_t *A, int m, int n);
void destroy(matrix_t *A);
void print(matrix_t *A); // 연산 결과 출력함수
void gauss(matrix_t *A); // 가우스 조던 계산함수
void create(matrix_t *A, int m, int n)
{
int i;
A-m = m;
A-n = n;
A-a = (double **)malloc( sizeof(double*) * m);
for(i=0; i m; i++)
{
A-a[i] = (double *)malloc( sizeof(double) * n);
}
}
void destroy(matrix_t *A)
{
int i;
for(i=0; i A-m; i++)
{
free(A-a[i]);
}
free(A-a);
A-m = A-n = 0;
A-a = 0;
}
void load(matrix_t *A, FILE *fptr)
{
int m, n;
int i, j;
fscanf(fptr,%d %d,&m,&n);
create(A,m,n);
for(i = 0; i A-m; i++)
{
for(j = 0; j A-n; j++)
{
fscanf(fptr,%lf, &A-a[i][j]);
}
}
}
void print(matrix_t *A)
{
int i, j;
for(i = 0; i A-m; i++)
{
for(j = 0; j A-n; j++)
{
printf( %.3f\t, A-a[i][j]);
}
puts();
}
puts();
}
void gauss(matrix_t *A)
{
int i, j, k;
double pivot;
printf(\n Gauss-Jordan Elimination 풀이 과정 : \n);
printf( ***************************************************** \n\n);
for(i=0; i A-m; i++)
{
pivot = A-a[i][i];
if(pivot == 0)
{
return;
}
for(j=i+1; j A-n; j++)
{
A-a[i][j] /= pivot;
}
A-a[i][i] = 1;
print(A);
for(k=0; k A-m; k++)
{
if(i == k) continue;
pivot = A-a[k][i];
for(j=i+1; j A-n; j++)
{
A-a[k][j] -= A-a[i][j] * pivot;
}
A-a[k][i] = 0;
}
print(A);
}
return;
}
int main()
{
int i = 0, j = 0;
int n;
matrix_t A;
FILE *fptr;
fptr = fopen(matrix.txt,rt);
load(&A,fptr);
print(&A);
gauss(&A);
for(i=0; i A.m; i++)
{
printf(X%d = %f\n,i+1,A.a[i][A.n-1]);
}
destroy(&A);
fclose(fptr);
}
-
상처입은마음
아..제가 메일로 보냈거든요.. 확인좀해주세요!
답변해주셔서 너무 감사해요!!!!!!!!!! -
은별
REF와 RREF 가 뭡니까?
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2695738 | fopen과fclose질문~~ (5) | 희선 | 2025-05-23 |
2695707 | 3의 배수 나타내기. (2) | 수리 | 2025-05-23 |
2695626 | 피보나치수열 과제 때문에 질문 드립니다. (6) | 옆집언니 | 2025-05-22 |
2695595 | 포인트공부중입니다 int형에서 4=1 인가요? (3) | 족장 | 2025-05-22 |
2695567 | 드라이브 고유번호를 가져오는 함수 (2) | 초코맛사탕 | 2025-05-21 |
2695533 | 음수의 산술변환! 질문이요 ㅠㅠ... (4) | 꽃여름 | 2025-05-21 |
2695506 | 구조체 배열 이용 도서목록 출력 프로그램 (1) | 가을귀 | 2025-05-21 |
2695450 | c언어 함수 질문이요.... | 이슬비 | 2025-05-20 |
2695403 | VirtualAlloc함수 및 메모리 질문 | 크리에이터 | 2025-05-20 |
2695355 | c언어 for함수 | 미쿡 | 2025-05-19 |
2695327 | 안녕하세요 제가 이번에 좀 큰 프로그램을.. | 악당 | 2025-05-19 |
2695295 | mutex동기화의 thread기반 채팅 서버소스 질문입니다 | 그루터기 | 2025-05-19 |
2695270 | 질문이요..swap 관한겁니다..ㅠㅠ (3) | 콩알녀 | 2025-05-19 |
2695244 | 노땅초보궁금한게 하나 있는데요..반복문(while문)초보자질문 (6) | 큰꽃늘 | 2025-05-18 |
2695166 | do while 문 어떤것이잘못된건지 모르겠어요 (2) | 아이폰 | 2025-05-18 |
2695122 | 구조체에 대해 물어보고 싶은게 있습니다 ^^^.. (7) | 수련 | 2025-05-17 |
2695091 | txt 파일 입출력 후 2차 배열에 저장하기입니다. (3) | 헛장사 | 2025-05-17 |
2695063 | 수도요금 프로그램좀 짜주세요. | 시내 | 2025-05-17 |
2695033 | 답변좀요ㅠㅠ (1) | 비사벌 | 2025-05-16 |
2695010 | C++의 STL은 왜 굳이 템플릿화 시켜서 라이브러리를 만드나요? (초보수준의 질문..) (2) | 엘보어 | 2025-05-16 |