연립방정식을 풀어주는 코드를 짰는데..
초코우유
제가 연립방정식을풀어주는 코드를짰는데 17행 넘어가니까프로그램작동이 중지됬다고 뜨네요..
뭐가 잘못됬길래 이런 코드가 뜨나요;
#include stdio.h
#include stdlib.h
#include string.h
#include math.h
#pragma warning(disable:4996)//
그냥 scanf경고 없애는거 신경노
노
double * sim(double (*pt)[3]);
int main(void)
{
double mat[2][3];
double * simret;
printf(첫번째 식의 x계
수 y계수 그리고 식의 값 : );
scanf(%lf %lf %lf,
&mat[0][0], &mat[0][1], &mat
[0][2]);
printf(두번째 식의 x계
수 y계수 그리고 식의 값 : );
scanf(%lf %lf %lf,
&mat[1][0], &mat[1][1], &mat
[2][2]);
simret=sim(mat);
printf(x=%f y=
%f,*simret, *(simret+1));
free(simret);
simret=NULL;
return 0;
}
double * sim(double (*pt)[3])
{
int i,j;
double * xy=(double
*)malloc(sizeof(double)*2);
double temp[2][3];
const double x1=pt[0]
[0], x2=pt[1][0],
y1=pt[0][1],
y2=pt[1][1];
for(i=0; i2; i++)
{
for(j=0; j3; i
++)
{
temp[i][j]=pt[i][j];//pt 연산하면
값이 변하기때문에 원본저장
}
}
for(i=0; i3; i++) //y값
알아내기(44-50)
{
pt[0][i] *= x2
;
pt[1][i] *= x1
;
}
xy[0]= pt[0][2] - pt
[1][2] / pt[0][1] - pt[1][1];
for(i=0; i3; i++) //x값
알아내기(52-58)
{
temp[0][i] *=
y2 ;
temp[1][i] *=
y1 ;
}
xy[1]= (temp[0][2] -
temp[1][2]) / (temp[0][0] -
temp[1][0]);
return xy;
}참고로 저는 연립방정식 푸는 방식을 코드로 바꿨습니다.
}
코드는 텍스트 파일에 저장해놨어요
-
아메
printf(\x=%f y=%f\
-
꽃짱구
void sim(double (*pt)[3])
{
int i,j;
double temp[2][3];
const double x1=pt[0][0], x2=pt[1][0],
y1=pt[0][1], y2=pt[1][1];
for(i=0; i2; i++)
{
for(j=0; j3; i++)
{
temp[i][j]=pt[i][j];//pt 연산하면 값이 변하기때문에 원본저장
}
}
for(i=0; i3; i++) //y값 알아내기(44-50)
{
pt[ -
펴라
double xy[2];
void sim(double (*pt)[3]);
int main(void)
{
\tdouble mat[2][3];
\t
\tprintf(\첫번째 식의 x계수 y계수 그리고 식의 값 : \);
\tscanf(\%lf %lf %lf\ -
도리도리
차라리 double xy[2]; 이렇게 배열로 전역변수로 만들어보세요.
-
콩알눈
음..xy변수는 동적할당된 메모리주소값이 저장됬고, sim함수 반환한 값을 simret에 저장했으니까
코드를 보시면 결과적으로는 힙영역주소값을 simret에 저장한거 아닌가요
그리고 xy나 simret이나 힙영역에 할당된 메모리주소가 저장됬으니까
free(simret)하고 simret에 눌포인터를 저장했으면 된거아닌가요 -
꼬붕
우선 sim 함수에서 xy 변수는 지역 변수이기 때문에 sim 함수가 끝난 순간에 값을 보증할 수 없게 됩니다.
그리고 xy는 동적할당을 하고 있는데, free하는 부분이 없으므로 메모리 유실 상황이 됩니다.
main에서 동적할당을 하고 sim 함수로 넘겨준 다음에 main 함수가 끝나는 부분에 free를 넣어주세요. -
시나브로
배열로 바꿨는데도 어디가 잘못됬는지 도통 보이지가 않네요ㅠㅠ
-
잉간
질문에 올라온 소스에서 가장 큰 문제점은
a[1][2]로 해서 간단하게 코딩을 해도 헷갈리는데 *(*(a+1)+2) 이런 식으로 코딩을 했기 때문에 어디가 잘못되어 있는지 구분하기 힘들게 됩니다. -
스위트초코
파일 올렸는데 못보셨네요...
-
겨울
이렇게 그림으로 올리면 다른 사람들은 컴파일을 해 볼 수도 없고, 실행시켜 볼 수도 없기 때문에 스스로 해결해야 됩니다.
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2676182 | 숫자 순서대로 배열하는법 | 권뉴 | 2024-11-24 |
2676152 | 기본적인거 하나 질문드립니다. | 개미 | 2024-11-24 |
2676124 | 함수선언관련 질문이에요~...털썩..수정완료 (2) | 가지 | 2024-11-24 |
2676092 | C언어 책 (2) | 아서 | 2024-11-24 |
2676065 | 웹사이트 또는 메신저 등에서 원하는 텍스트를 검사하는방법?? (1) | 모든 | 2024-11-23 |
2676033 | 배열 기초연습중 발생하는 에러 ㅠㅜ... | Creative | 2024-11-23 |
2676005 | keybd_event 게임 제어 | 영글 | 2024-11-23 |
2675900 | 진짜기본적인질문 | 글길 | 2024-11-22 |
2675845 | 수정좀해주세요ㅠㅠㅠ | 해골 | 2024-11-21 |
2675797 | 병합 정렬 소스 코드 질문입니다. (2) | 도래솔 | 2024-11-21 |
2675771 | 큐의 활용이 정확히 어떻게 되죠?? | 해긴 | 2024-11-21 |
2675745 | 도서관리 프로그램 질문이요 | 도리도리 | 2024-11-20 |
2675717 | 2진수로 변환하는것! (3) | 동생몬 | 2024-11-20 |
2675599 | for문 짝수 출력하는 법 (5) | 널위해 | 2024-11-19 |
2675575 | Linux 게시판이 없어서.. | 첫삥 | 2024-11-19 |
2675545 | 구조체 이용할 때 함수에 자료 넘겨주는 것은 어떻게 해야 하나요? | 아연 | 2024-11-19 |
2675518 | 사각형 가로로 어떻게 반복해서 만드는지좀.. 내용 | 신당 | 2024-11-18 |
2675491 | !느낌표를 입력하는것은 어떻게합니까~~?ㅠㅠ (5) | 사지타리우스 | 2024-11-18 |
2675411 | 파일입출력으로 받아온 파일의 중복문자열을 제거한 뒤 파일출력 | 앨버트 | 2024-11-17 |
2675385 | 링크드리스트 주소록 질문드립니다. (1) | 겨루 | 2024-11-17 |