录入学生信息排序fwrite fread 冒泡

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define N 2
struct STU {
    int id;
    char name[20];
    char sex;
    int score;
};
void show_stu(struct STU *s, int n)
{
    int i; 
    for (i = 0; i < n; i++)
        printf("%d\t%s\t%c\t%d\n", s[i].id, s[i].name, s[i].sex, s[i].score);
}

void write_stu(struct STU *s, int n, FILE *fp)
{
    //fwrite
    int i;
    for (i = 0; i < n; i++) 
        fwrite(&s[i], sizeof(*s), 1, fp);
}

struct STU *read_stu(FILE *fp, int *n)
{
    int i, res, m = 10;
    struct STU *s = (struct STU *)malloc(sizeof(struct STU) * m);
    for (i = 0; ; i++) {
        if (i == m) {
            m *= 2;
            s = realloc(s, sizeof(struct STU) * m);
        }
        if (!fread(&s[i], sizeof(struct STU), 1, fp))
            break;
    }
    *n = i;
    return s;
}

void sort_stu(struct STU *s, int n)
{
    int i, j;
    struct STU tmp;

    for (i = 0; i < n-1; i++)
        for (j = 1; j < n-i; j++) 
            if (s[j-1].score < s[j].score) {
                tmp = s[j-1];
                s[j-1] = s[j];
                s[j] = tmp;
            }
}
int main(void)
{
    struct STU *student;
    FILE *fp, *fp_sort;
    int n = 0;

    fp = fopen("stu.txt", "r");
    if (!fp) {
        printf("fopen stu.txt err\n");
        return 1;
    }
    
    fp_sort = fopen("stu_sort.txt", "w");
    if (!fp_sort) {
        printf("fopen stu_sort.txt err\n");
        return 1;
    }
    student = read_stu(fp, &n);
    //show_stu(student, n);
    sort_stu(student, n);
    //printf("******\n");
    show_stu(student, n);
    write_stu(student ,n, fp_sort);

    free(student);
    fclose(fp);
    fclose(fp_sort);
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值