함수에서 함수로 특정 값 넘기기와 매개변수선언
어리버리
질문 제목 :
메뉴에서 1번을 누르고 input함수로 입력받습니다.
그리고 2번을 눌려서 sort함수로 평균점수를 기준으로정렬하는 프로그램입니다.
참고로 메모리는 malloc으로 할당했습니다.
sort함수에서 성적순으로 정렬하려면 input 함수에서 몇 개의 데이터를 입력받았는지 알아야
for문으로 몇개의 데이터를 비교할지 정할 수 있습니다.
input 함수에서 i 가 몇개의 데이터를 입력받았는지 카운트하는 역할을 합니다.
이 i 를 sort함수에 넘겨주어야 하는데 그 방법을 모르겠습니다.
return 으로 넘기나요? 아니면 다른 방법이 있나요?
색처리 된 부분들이 세부 질문입니다.
그리고 막연한 답변보다는 자세한 설명을 해주셨으면 좋겠습니다.
질문 내용 :
typedef struct STUDENT{
int num; //번호
char name[20]; //이름
int avg; //평균
}student;
student *data;
student temp;
//함수선언
int input(); //입력함수
void sort(struct STUDENT *data, int i); //정렬함수
//STUDENT를 student로 하면 안되더군요. student *data가 아닌 STUDENT *data인 이유는 무엇인가요?
//i 값을 int i 로 넘기는 것이 맞나요?
void main()
{
switch(menu)
{
case 1:
input();
break;
case 2:
sort(data,i);//main 안에서는 data, i 이렇게만 선언했습니다.
int input()
{
int i=0;
int j=0;
data=(student*)malloc(sizeof(student)*5);
. //scanf로 번호, 이름, 평균을 입력 받습니다.
.
free(data);
return i; //만약 return으로 i값을 넘겨주는 것이 맞다면free밑에서 넘겨주어야 할 것 같습니다.
sort(data,i); //만약 return이 아니라면 sort() 방식으로 넘겨주나요?
}
void sort(struct STUDENT *data, int i)//sort에서 input에서 넘겨준 i 값을 받음
{
int j=0;
int k=0;
data=(student*)malloc(sizeof(student)*5); //3개의 구조체를 저장할 메모리 할당
//버블정렬, 평균을 기준으로 오름차순 정렬
for(j=0; j(i-1); j++) 넘겨준 i 는 for 루프를 몇번 도는지 결정하는 역할을 합니다.
for(k=(j-1); ki; k++)
if((data+j)-avg(data+k)-avg)
{
temp=*(data+j);
*(data+j)=*(data+k);
*(data+k)=temp;
}
}
-
피리
답변 감사합니다.
-
희나리
void sort(PS_STUDENT _pHeader){
\tPS_STUDENT _node = _pHeader-next;
\twhile(_node-next){//끝인가?
\t\t//정렬알고리즘적용
\t}
\t//정렬이 완료
}
//링크드 리스트로 했습니다.
//count를 할려고 했더니 약간 복잡해진듯해서 링크드 리스트 추가해서 달았습니다. -
지율
//헤더에 데이타를 생성해서 달아주기
void input(PS_STUDENT _pHeader){
\t//1. 동적메모리 생성
\tPS_STUDENT _p = (PS_STUDENT)malloc(sizeof(STUDENT));
\t//2. 사용자로 부터 데이타 입력 받기....
\t//3. 헤더에 만들어준 메모리 연결하기
\t_pHeader-next = _p;//헤더엘 달아주기
\t_p-next = NULL;//끝을 찾기 위해서 반드시 NULL처리
\t -
아쿠아리우스
void main(){
\tPS_STUDENT pHeader = NULL;
\tSTUDENT p;//해더용 데이타를 안들어감
\tpHeader = &p;
\t
\t//.....
\tinput(pHeader);//링크드 리스트로 여기에 달아서 넘겨주는곳
\t//...
\tsort(pHeader);
} -
중독적
typedef struct STUDENT * PS_STUDENT;
typedef struct STUDENT{
\tint num;
\tchar name[20];
\tint avg;
\tPS_STUDENT next;//링크드 리스트로 연결하기 위해서
}student;
void input(PS_STUDENT);
void sort(PS_STUDENT); -
양자리
그리고
main문 case 에서는
sort(data); //i 뺌
void sort(struct STUDENT *data) //여기서도 i 뺌
{
//i를 전역으로 선언하였으므로 매개변수로 안 받고 그냥 씀
}
틀린 부분이 있다면 한 번 더 설명 부탁드립니다. -
주리
그럼 아래와 같이 하는 것이 맞나요?
#includestdio.h
typedef struct STUDENT{
int num;
char name[20];
int avg;
}student;
student data[10];
int i; //return 으로 넘기지 않고 i 를 전역으로 선언
void main()
{
struct STUDENT *temp;
temp=data;
} -
유진공주
1. STUDENT를 student로 하면 안되더군요. student *data가 아닌 STUDENT *data인 이유는 무엇인가요?
= typedef struct STUDENT * PS_STUDENT;
typedef struct STUDENT{
....
}student;
로해서 간편하게 PS_STUDENT data로 포인터 구조체용으로 사용하시면 쉽게 이해가능
2. i의 값을 함수 바로 받아서 처리하는 방법도 있지만 전역변수로 -
루리
전체적인 식이 조금 이상하네요...
1. input에서 데이타를 입력 받아서 데이타를 동적으로 저장했는데 그 동적인 데이타를 free(메모리에서 제거해버리네요 헐)해버리면 뭘 정리 하실려고요?
2. sort에서 데이타를 받았는데 그 data에 다른 새로운 생성 메모리를 할당? 좀 먼가 이상하네요...
ㅎㅎㅎ;
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
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 |
2675356 | 2진수를 10진수로 바꾸려고 하는데 막히네요.. | 풀잎 | 2024-11-17 |