구조체 포인트와 배열에 관해서 궁금한 점이 있습니다.
찬바리
굵은 글씨로 표시된 순위대로 정렬하기 소스가 이해가 안갑니다.
순위대로 정렬하기 소스 분석!!!질문 내용 :
#include stdio.h#define ninzu 5
#define kamoku 4struct seiseki { /* 성적데이타*/
int no; /* 학생번호 */
int ten[kamoku]; /* 점수*/
int goukei; /* 합계점 */
};int main( void )
{
struct seiseki mycls[ninzu] = {
{ 1001, 85, 74, 63, 90, 0 },
{ 1002, 78, 65, 70, 62, 0 },
{ 1002, 78, 65, 70, 62, 0 },
{ 1004, 32, 48, 66, 25, 0 },
{ 1005, 92, 76, 81, 98, 0 },
}; struct seiseki *sp;
struct seiseki wk;
int i, j; sp = mycls; printf( 번호 국어 수학 물리 사회 합계\n );
for ( i = 0; i ninzu; i++ ) {
/*** 합계구하는 식 ***/
for ( j = 0; j kamoku; j++ ) {
( sp+i )-goukei = ( sp+i )-goukei + ( sp+i )-ten[j];
}
}
/*** 합계득점순으로 정렬 ***/
for ( i = 0; i ninzu-1; i++ ) {
for ( j = 0; j ninzu-i-1; j++ ) {
if( ( sp+j )-goukei ( sp+j+1 )-goukei ) {
wk = *( sp+j );
*( sp+j ) = *( sp+j+1 );
*( sp+j+1 ) = wk;
}
}
}구조체 변수 wk에 왜 포인트가 가르키고 있는 값인 *(sp+j)을 대입 하는지 이해가 안갑니다.제 생각은 구조체 멤버를 다 wk에 대입하기 위해서는(sp+j)의 주소를 넘겨줘야 하지 않을까 생각 했습니다.물론 (sp+j)로 넘겨주면 오류가 나옵니다.그래서 printf(%d\n,*(sp+j))를 출력해 본 결과 학생 번호 1001이 출력 되었습니다.결론은 학생 번호만 wk로 넘겨주는데 각 과목의 점수와 합계가 같이 넘어가는지 이부분이 이해가 안갑니다. 고수님들 답변 기다리고 있겠습니다. /*** 결과 표시 ***/
for ( i = 0; i ninzu; i++ ) {
printf( %4d , ( sp+i )-no );
for ( j = 0; j kamoku; j++ )
printf(%4d , ( sp+i )-ten[j] );
printf( %4d\n, ( sp+i )-goukei );
}
return 0;
}