퀵sort로 내림차순 정렬
민구
질문 제목 : 퀵소트로 평균을 내림차순 정렬하는 것입니다계속 오류가 뜨는데 어떻게 고쳐야 제대로 나올지 모르겟습니다. 어디를 어떻게 고쳐야 하나요?질문 내용 :
소스코드
#include stdio.h
#define max_student 3
void qsort(struct student* average[], int n);
void swap(double *, double *);
struct student {
char name[20];
int korean, english, math;
double average;
};
int main(void)
{
struct student std[max_student];
int i;
//double total_average = 0;
printf(%d 명의 학생 정보를 입력하세요.\n, max_student);
for(i = 0 ; i max_student ; i++)
{
printf(이름 : );
scanf(%s, std[i].name);
printf(국어, 영어, 수학 점수 : );
scanf(%d %d %d, &std[i].korean,
&std[i].english, &std[i].math);
std[i].average = (double)
(std[i].korean + std[i].english + std[i].math) / 3;
}
qsort(&std[i].average, max_student);
for(i = 0 ; i max_student ; i++)
printf(%6.2f , std[i].average);
printf(\n);
return 0;
}
void qsort(struct student* average[], int n)
{
int left = 0, right = n;
double key = average[0];
int i;
if( n = 1 )
return;
for(i = 0 ; i n ; i++)
printf(%d , average[i]);
printf(\n);
while(1)
{
while(average[++left] key);
while(average[--right] key);
if( left = right )
break;
swap(&average[left], &average[right]);
}
swap(&average[0], &average[right]);
for(i = 0 ; i n ; i++)
printf(%d , average[i]);
printf(\n);
qsort(average, right);
qsort(average + right + 1, n - right - 1);
}
void swap(double *x, double *y)
{
double temp = *x;
*x = *y;
*y = temp;
}
-
뿌우 2023-04-26
평균을 정렬하려면, 평균들의 저장된 배열을 만들어서,
그 배열을 정렬하세요. 의미가 있는지는 모르겠지만...
의미 있는 자료 처리가 되려면,
평균을 기준으로 학생들의 자료를 정렬하는 것이 좋겠습니다만...
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
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 |
2675297 | Prity 비트 발생기 | 한란 | 2024-11-16 |
2675249 | C책 좀 추천해 주세요 (2) | 딸기우유 | 2024-11-16 |