가우스 소거법 코드 짜는데 오류가 나네요
세라
질문 제목 : 가우스 코드 짜는데 오류가나요.빌드는 되는데 프로그램 실행중 오류가 나네요
어쩔때는 끝까지 다되고도 멀쩡하고 어쩔때는 안되고 합니다.
인풋파일에서 n을 입력 받아서 n*n만큼의 숫자를 읽어드린후
가우스 소거법을 실행하는 코드입니다.
질문 내용 :소스코드 입니다.#include stdio.h
#include string.h
#include stdlib.h
#include share.h
#define filename c:\\download\\input.txt
void removing(float arr[10][10],int cou){ int i,j,k;
int n=1;
float p; puts(소거법 끝난후);
for(i=0;icou;i++){
for(j=i+1;jcou;j++){
p=(float)arr[j][i]/arr[i][i];
for(k=i;kcou;k++){
arr[j][k]=arr[j][k] - p*arr[i][k];
}
}
}
}void exchange(float arr[10][10],int cou){ int i,j;
int n;
float temparr[10]; for(n=0;ncou*cou;n++){
if(arr[n][0]==1||arr[n][0]==-1){
for(i=0;icou-1;i++){
for(j=0;jcou;j++){
temparr[j]= arr[i][j];
arr[0][j] = arr[n][j];
arr[n][j] = temparr[j];
}
break;
}
}
} puts(교환중);
for(i=0;icou;i++){
for(j=0;jcou;j++){
printf(%4.2f ,arr[i][j]);
}
printf(\n);
} removing(arr,cou);
}
float upper_matrix(file *fd,file *rfd){ int i,j;
float arr[10][10];
int cou;// n*n정방행렬.
fscanf_s(fd,%d,&cou,1);
printf(%d x %d 행렬\n\n,cou, cou);
for(i=0;icou;i++){
for(j=0;jcou;j++){
fscanf_s(fd,%f,&arr[i][j],1);
printf(%3.2f ,arr[i][j]);
}
printf(\n);
} exchange(arr,cou); for(i=0;icou;i++){
for(j=0;jcou;j++)
printf(%3.2f ,arr[i][j]);
printf(\n);
}
for(i=0;icou;i++){
for(j=0;jcou;j++)
fprintf(rfd,%3.2f ,arr[i][j]); fprintf(rfd,\n);
} return 0;
}
void fatal(char *message){ //에러 메세지 출력/ char error_message[100]; strcpy_s(error_message,15, 에러!! );
strcat_s(error_message,100,message);
perror(error_message);
exit(-1);
}int main(){
int i;
file *fd,*rfd;
if((fd = _fsopen(filename,r,_sh_denyno))==null)
fatal(파일 열던중);
if((rfd= _fsopen(c:\\download\\output.txt,a,_sh_denyno))==null)
fatal(아웃풋 파일 만들던중.); for(i=0;i=8;i++){
fprintf(rfd,*************%d x %d**********\n,i+2,i+2);
upper_matrix(fd,rfd);
fprintf(rfd,\n);
}
fclose(fd);
fclose(rfd); return 0;
}
-
연와인
과제의 조건이라 어쩔 수 없이 썻지만 동감하네여 컴턴데 이럴 필요가 있는지 ㅎㅎ
말씀하신데로 함수는 분리해야겠네요 감사합니다. -
가랑비
피봇이 0 이 되는 경우 행을 바꾸어 해결하지만,
이렇게 하는 필요가 있을까요?
그리고,
파일에서 행렬을 읽는 함수와 파일에 행렬을 쓰는 함수,
계산하는 함수를 분리하는 것이 좋겠습니다. -
노랑이
행 바꿈 함수입니다. 첫번째 열에 1이나 -1이 있으면 그 행과 첫번째 행을 바꾸는 함수입니당
-
로지
그런데, exchange 함수의 역할이 뭔가요?
-
해길
음 그렇군요. 근데 왜 프로그램이 성공할 때도 있고 실패할 때도 있는지가 궁금하네요 ...
-
미리별
문자열이나 문자를 받는 경우가 아니면, _s 류의 함수를 사용할 필요가 없습니다.
안정성을 따질 이유가 없기 떄문입니다. -
횃눈썹
그럼 _s 류의 함수를 안쓰면 되는건가요??
-
바로찬글
scanf_s 류의 함수는 %c, %s, %[] 만 추가 인자 뒤에 버퍼 크기를 추가합니다.
fscanf_s(fd,\%d\
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2692256 | scanf("%*c"); ㅠㅠ 고수님들 | 거북이 | 2025-04-21 |
2692230 | 하노이탑 질문입니다. (1) | 미쁘다 | 2025-04-21 |
2692210 | 정보 올림피아드 문제인데.. 풀이 과정이 궁금합니다.(재귀함수) (5) | 물티슈 | 2025-04-20 |
2692144 | C언어와 리눅스에 대한 질문입니다. | 싴흐한세여니 | 2025-04-20 |
2692114 | 컨텍스트 스위칭하는데 걸리는 시간 측정.. | YourWay | 2025-04-19 |
2692086 | 간접참조 연산자, 증감연산자 질문이용! (2) | 블랙캣 | 2025-04-19 |
2692056 | 주석좀 달아주세요. 몇개적엇는데 몇개만달아주세요. (2) | DevilsTears | 2025-04-19 |
2691978 | 진수 쉽게 이해하는법... (3) | 지지않는 | 2025-04-18 |
2691949 | getchar() 한 문자를 입력받는 함수 질문 | 채꽃 | 2025-04-18 |
2691919 | 배열 정렬 및 합치기 질문입니다. | 사과 | 2025-04-18 |
2691845 | c언어왕초보 질문이 있습니다........ | 루나 | 2025-04-17 |
2691815 | void add(int num); 함수... (4) | 살랑살랑 | 2025-04-17 |
2691756 | 명령 프롬프트 스크롤바가 없어요 | 두메꽃 | 2025-04-16 |
2691725 | 자료구조에 관련해서 질문이 있어 글을 올립니다. | 누리알찬 | 2025-04-16 |
2691697 | if 문에서 구조체 배열에 저장되있던 문자열 검사하는 법 ? (2) | 민트맛사탕 | 2025-04-16 |
2691678 | C언어 함수 질문이요~!!! | 연보라 | 2025-04-15 |
2691650 | 반복문 | 돋가이 | 2025-04-15 |
2691618 | 링크드리스트 개념 질문이예요 (3) | 맨마루 | 2025-04-15 |
2691592 | 동적할당 이용 배열선언 질문입니다.ㅠㅠ (3) | 허리달 | 2025-04-15 |
2691542 | /=의 용도를 알려주세요 ㅠㅠ! (2) | 아라 | 2025-04-14 |