작은숲:위키노트/C 언어 예제/입력된 내용을 구조체에 저장하고 정렬하기

큰숲백과, 나무를 보지 말고 큰 숲을 보라.
/**
 * Copyright (c) 2001,2002 Yoon, Hyunho <hhyoon@kldp.org>
 * http://mooo.org
 * ----------------------------------------------------------------------
 *
 * LICENSE
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation; either version 2
 * of the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software 
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
 */
/**
 * 1. 구조체를 선언하여 사용자 입력을 받아 그것을 구조체 배열에 저장한다.
 * 2. 구조체 배열에 저장된 내용을 평균을 기준으로 정렬을 한다.
 * 3. 구조체 배열에 저장된 내용을 출력한다.
 */
#include <stdio.h>
#define MAX_NAME        30
#define MAX_STUDENTS    100
// 구조체 선언 ..
// typedef문을 사용해 사용자 정의 데이터형을 만든다.
struct _student
{    char name[MAX_NAME];
    int num;
    int korean;
    int english;
    int math;
    int science;
    int computer;
    float average;
};
typedef struct _student Student;
void input(Student *student, int num);
void sort(Student *student, int num);
void print(Studnet *student, int num);
void main()
{    int num;
   // 구조체 Student의 배열과 변수를 선언한다.
    Student student[MAX_STUDENTS], temp;
    printf("Enter the number of stduents: ");
    scanf("%d", &num);
    input(student, num);
    print(student, num);
    sort(student, num);
    print(student, num);
}void input(Student *student, int num)
{    int i;
    for (i = 0; i < num; i++) {
       // scanf() 함수가 '\n'을 입력버퍼에 그대로 남겨두기 때문에
       // 이 '\n'을 없애줘야 한다.
        flushall();
        printf("Enter the name#%d: ", i + 1);
        gets(student[i].name);
        printf("Ehter the student num and the scores of ");
        printf(" Korean, English, Math, Science, Computer: ");
        scanf("%d %d %d %d %d %d", &student[i].num, &student[i].korean,
            &student[i].english, &student[i].math, &student[i].science,
            &student[i].computer);
       // 입력값 검사
        if (!(student[i].num >= 920000 && student[i].num <= 929999)) {
            printf("바보야! 다시 입력해!\n");
            i--;
            continue;
        }
        student[i].average = (student[i].korean + student[i].english
            + student[i].math + student[i].science + student[i].computer) / (float) 5.0;
    }
}void sort(Student *student, int num)
{    int i, j;
   // 각 학생의 평균을 기준으로 정렬을 한다.
    for (i = 0; i < num - 1; i++) {
        for (j = 0; j < num - 1; j++) {
            if (student[j].average < student[j + 1].average) {
                temp = student[j];
                student[j] = student[j + 1];
                student[j + 1] = temp;
            }
        }
    }
}void print(Studnet *student, int num)
{    int i;
   // 입력받은 값을 printf() 함수의 형식 지정자를 사용하여 출력한다.
    printf("\n=======================================================\n");
    printf("%-15s %-6s    %-4s %-4s %-4s %-4s %-4s %-5s\n", "Name", "Num",
        "Kor", "Eng", "Math", "Sci", "Com", "Avg");
    printf("=======================================================\n");
    for (i = 0; i < num; i++) {
        printf("%-15s(%6d): %4d %4d %4d %4d %4d %5.1f\n", student[i].name, student[i].num,
            student[i].korean, student[i].english, student[i].math,
            student[i].science, student[i].computer, student[i].average);
    }
    printf("=======================================================\n");
}
이 작은숲 문서의 출처는 위키노트의 위키노트/C 언어 예제/입력된 내용을 구조체에 저장하고 정렬하기 문서입니다.