4시간 후면 시험인데 이거 모르겠네요 좀 도움좀 주세요
안녕하세요? 4시간 후면 시험 보는데 통 어떻게 해야 할지 모르겠네요 ㅠㅠ
좀 도움좀 얻을 수 있을까요 다른건 다 해결 했는데 디버깅만 잘모르겠네요
리눅스 프로그래밍 입니다.
#include
typedef struct {
char data[4096];
int key;
} item;
item array[] = {
{“bill”, 3},
{“neil”, 4},
{“john”, 2},
{“rick”, 5},
{“alex”, 1},
};
sort(a,n)
item *a;
{
int I = 0, j = 0;
int s = 1;
for(; i < n && s != 0; i++) {
s = 0;
for(j = 0; j < n; j++) {
if(a[j].key > a[j+1].key) {
item t = a[j];
a[j] = a[j+1];
a[j+1] = t;
s++;
}
}
n--;
}
}
main()
{
int i;
sort(array,5);
for(i = 0; i < 5; i++)
printf("array[%d] = {%d, %s}\n“, i, array[i].key, array[i].data);
}
(1)
if(a[j].key > a[j+1].key) {
바로 앞에서
#ifdef DEBUG
…
#endif
를 이용하여 j값을 출력하도록 프로그램을 수정하고,
$ gcc –DDEBUG 파일명
으로 컴파일 후 실행해 보라.
j값이 얼마일 때 segmentation fault가 발생하고, 또 그 이유는 무엇인가 생각해 보라.
(2) (1)에서 발생한 문제를 해결하기 위해 프로그램을 수정하여라.
(3) 수정후 다시 실행하면 다음과 같이 잘못된 결과가 출력될 것이다.
array[0] = {2, john}
array[1] = {1, alex}
array[2] = {3, bill}
array[3] = {4, neil}
array[4] = {5, rick}
(4) n--;
바로 밑에서
#ifdef DEBUG
…
#endif
를 이용하여 n값을 출력하도록 프로그램을 수정하고,
$ gcc –DDEBUG 파일명
으로 컴파일 후 실행해 보라.
n값이 얼마일 때 프로그램이 종료되고, 또 그 이유는 무엇인가 생각해 보라.
(5) (4)에서 발생한 문제를 해결하기 위해 프로그램을 수정하여라
참 친절하신
참 친절하신 선생님을 두셨네요. 어떤식으로 접근해서 디버깅을 해야 할지도 알려주고 있으니까요.
생각하는 부분은 그렇다치더라도, 친절한 선생님을 위해서 최소한 하라고 한 부분까지는 해보는 노력을 하면 좋을 것 같다는 생각이 듭니다. 숙제 도와주는것에 인색한편은 아니지만 어느부분까지 해봤는데 어느부분이 이해가 잘 안간다라고 올리셨으면 많이들 도와주실것 같습니다.
아 제 생각이
아 제 생각이 짧았네요 너무 급한 나머지 오늘 하루만 3개를 시험을 봐야되서 마음의 여유가 없었네요 ㅠㅠ
앞 부분은 다 이해 했는데 이 디버깅 부분은 어떻게 시작해야 할지 몰라서 이렇게 올렸습니다.
지금 열심히 해보고 있는데 잘 않되네요 ㅠㅠ 충고 감사합니다 ^^
댓글 달기