百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

C语言实现学生成绩管理

itomcoil 2025-03-12 15:52 5 浏览

下面是一个用C语言实现的简单成绩管理系统,满足你提出的所有要求。这个程序使用链表来存储学生信息,支持录入、查询、排序、保存、修改和删除学生成绩等功能。

#include 
#include 
#include 

// 定义学生结构体
typedef struct Student {
    char name[50];
    int score;
    struct Student* next;
} Student;

// 全局变量,指向链表头
Student* head = NULL;

// 函数声明
void addStudent();
void displayStudents();
void searchStudent();
void saveToFile();
void loadFromFile();
void sortStudents();
void modifyStudent();
void deleteStudent();

int main() {
    int choice;
    while (1) {
        printf("\n成绩管理系统\n");
        printf("1. 录入成绩\n");
        printf("2. 查询成绩\n");
        printf("3. 显示所有成绩\n");
        printf("4. 保存成绩到文件\n");
        printf("5. 从文件加载成绩\n");
        printf("6. 按成绩排序\n");
        printf("7. 修改学生信息\n");
        printf("8. 删除学生成绩\n");
        printf("9. 退出\n");
        printf("请选择操作: ");
        scanf("%d", &choice);

        switch (choice) {
            case 1:
                addStudent();
                break;
            case 2:
                searchStudent();
                break;
            case 3:
                displayStudents();
                break;
            case 4:
                saveToFile();
                break;
            case 5:
                loadFromFile();
                break;
            case 6:
                sortStudents();
                break;
            case 7:
                modifyStudent();
                break;
            case 8:
                deleteStudent();
                break;
            case 9:
                exit(0);
            default:
                printf("无效选择,请重试。\n");
        }
    }
    return 0;
}

// 添加学生
void addStudent() {
    Student* newStudent = (Student*)malloc(sizeof(Student));
    if (newStudent == NULL) {
        printf("内存分配失败!\n");
        return;
    }

    printf("请输入学生姓名: ");
    scanf("%s", newStudent->name);
    printf("请输入学生成绩: ");
    scanf("%d", &newStudent->score);

    newStudent->next = head;
    head = newStudent;

    printf("学生成绩已添加。\n");
}

// 显示所有学生
void displayStudents() {
    Student* temp = head;
    if (temp == NULL) {
        printf("没有学生记录。\n");
        return;
    }

    printf("学生成绩列表:\n");
    while (temp != NULL) {
        printf("姓名: %s, 成绩: %d\n", temp->name, temp->score);
        temp = temp->next;
    }
}

// 查询学生
void searchStudent() {
    char name[50];
    printf("请输入要查询的学生姓名: ");
    scanf("%s", name);

    Student* temp = head;
    while (temp != NULL) {
        if (strcmp(temp->name, name) == 0) {
            printf("姓名: %s, 成绩: %d\n", temp->name, temp->score);
            return;
        }
        temp = temp->next;
    }

    printf("未找到该学生。\n");
}

// 保存到文件
void saveToFile() {
    FILE* file = fopen("students.txt", "w");
    if (file == NULL) {
        printf("无法打开文件。\n");
        return;
    }

    Student* temp = head;
    while (temp != NULL) {
        fprintf(file, "%s %d\n", temp->name, temp->score);
        temp = temp->next;
    }

    fclose(file);
    printf("成绩已保存到文件。\n");
}

// 从文件加载
void loadFromFile() {
    FILE* file = fopen("students.txt", "r");
    if (file == NULL) {
        printf("无法打开文件。\n");
        return;
    }

    // 清空当前链表
    Student* temp;
    while (head != NULL) {
        temp = head;
        head = head->next;
        free(temp);
    }

    char name[50];
    int score;
    while (fscanf(file, "%s %d", name, &score) != EOF) {
        Student* newStudent = (Student*)malloc(sizeof(Student));
        strcpy(newStudent->name, name);
        newStudent->score = score;
        newStudent->next = head;
        head = newStudent;
    }

    fclose(file);
    printf("成绩已从文件加载。\n");
}

// 按成绩排序
void sortStudents() {
    if (head == NULL) {
        printf("没有学生记录。\n");
        return;
    }

    Student *i, *j;
    int tempScore;
    char tempName[50];

    for (i = head; i != NULL; i = i->next) {
        for (j = i->next; j != NULL; j = j->next) {
            if (i->score < j->score) {
                // 交换成绩
                tempScore = i->score;
                i->score = j->score;
                j->score = tempScore;

                // 交换姓名
                strcpy(tempName, i->name);
                strcpy(i->name, j->name);
                strcpy(j->name, tempName);
            }
        }
    }

    printf("学生成绩已按从高到低排序。\n");
}

// 修改学生信息
void modifyStudent() {
    char name[50];
    printf("请输入要修改的学生姓名: ");
    scanf("%s", name);

    Student* temp = head;
    while (temp != NULL) {
        if (strcmp(temp->name, name) == 0) {
            printf("请输入新的成绩: ");
            scanf("%d", &temp->score);
            printf("学生成绩已修改。\n");
            return;
        }
        temp = temp->next;
    }

    printf("未找到该学生。\n");
}

// 删除学生
void deleteStudent() {
    char name[50];
    printf("请输入要删除的学生姓名: ");
    scanf("%s", name);

    Student *temp = head, *prev = NULL;
    while (temp != NULL) {
        if (strcmp(temp->name, name) == 0) {
            if (prev == NULL) {
                head = temp->next;
            } else {
                prev->next = temp->next;
            }
            free(temp);
            printf("学生成绩已删除。\n");
            return;
        }
        prev = temp;
        temp = temp->next;
    }

    printf("未找到该学生。\n");
}

功能说明:

  1. 录入成绩:通过 addStudent() 函数,用户可以输入学生姓名和成绩,并将其添加到链表中。
  2. 查询成绩:通过 searchStudent() 函数,用户可以输入学生姓名,程序会查找并显示该学生的成绩。
  3. 显示所有成绩:通过 displayStudents() 函数,程序会显示链表中所有学生的成绩。
  4. 保存成绩到文件:通过 saveToFile() 函数,程序会将链表中的学生成绩保存到本地文件 students.txt 中。
  5. 从文件加载成绩:通过 loadFromFile() 函数,程序会从 students.txt 文件中加载学生成绩到链表中。
  6. 按成绩排序:通过 sortStudents() 函数,程序会按成绩从高到低对学生进行排序。
  7. 修改学生信息:通过 modifyStudent() 函数,用户可以修改指定学生的成绩。
  8. 删除学生成绩:通过 deleteStudent() 函数,用户可以删除指定学生的成绩。

使用方法:

  1. 编译并运行程序。
  2. 根据提示选择相应的操作。
  3. 程序会将学生成绩保存到 students.txt 文件中,下次运行时可以从文件中加载数据。

注意事项:

  • 该程序是一个简单的示例,未处理所有可能的异常情况(如文件不存在、内存分配失败等)。
  • 可以根据实际需求进一步扩展功能,例如增加输入验证、支持更多学生信息等。

相关推荐

Excel新函数TEXTSPLIT太强大了,轻松搞定数据拆分!

我是【桃大喵学习记】,欢迎大家关注哟~,每天为你分享职场办公软件使用技巧干货!最近我把WPS软件升级到了版本号:12.1.0.15990的最新版本,最版本已经支持文本拆分函数TEXTSPLIT了,并...

Excel超强数据拆分函数TEXTSPLIT,从入门到精通!

我是【桃大喵学习记】,欢迎大家关注哟~,每天为你分享职场办公软件使用技巧干货!今天跟大家分享的是Excel超强数据拆分函数TEXTSPLIT,带你从入门到精通!TEXTSPLIT函数真是太强大了,轻松...

看完就会用的C++17特性总结(c++11常用新特性)

作者:taoklin,腾讯WXG后台开发一、简单特性1.namespace嵌套C++17使我们可以更加简洁使用命名空间:2.std::variant升级版的C语言Union在C++17之前,通...

plsql字符串分割浅谈(plsql字符集设置)

工作之中遇到的小问题,在此抛出问题,并给出解决方法。一方面是为了给自己留下深刻印象,另一方面给遇到相似问题的同学一个解决思路。如若其中有写的不好或者不对的地方也请不加不吝赐教,集思广益,共同进步。遇到...

javascript如何分割字符串(javascript切割字符串)

javascript如何分割字符串在JavaScript中,您可以使用字符串的`split()`方法来将一个字符串分割成一个数组。`split()`方法接收一个参数,这个参数指定了分割字符串的方式。如...

TextSplit函数的使用方法(入门+进阶+高级共八种用法10个公式)

在Excel和WPS新增的几十个函数中,如果按实用性+功能性排名,textsplit排第二,无函数敢排第一。因为它不仅使用简单,而且解决了以前用超复杂公式才能搞定的难题。今天小编用10个公式,让你彻底...

Python字符串split()方法使用技巧

在Python中,字符串操作可谓是基础且关键的技能,而今天咱们要重点攻克的“堡垒”——split()方法,它能将看似浑然一体的字符串,按照我们的需求进行拆分,极大地便利了数据处理与文本解析工作。基本语...

go语言中字符串常用的系统函数(golang 字符串)

最近由于工作比较忙,视频有段时间没有更新了,在这里跟大家说声抱歉了,我尽快抽些时间整理下视频今天就发一篇关于go语言的基础知识吧!我这我工作中用到的一些常用函数,汇总出来分享给大家,希望对...

无规律文本拆分,这些函数你得会(没有分隔符没规律数据拆分)

今天文章来源于表格学员训练营群内答疑,混合文本拆分。其实拆分不难,只要规则明确就好办。就怕规则不清晰,或者规则太多。那真是,Oh,mygod.如上图所示进行拆分,文字表达实在是有点难,所以小熊变身灵...

Python之文本解析:字符串格式化的逆操作?

引言前面的文章中,提到了关于Python中字符串中的相关操作,更多地涉及到了字符串的格式化,有些地方也称为字符串插值操作,本质上,就是把多个字符串拼接在一起,以固定的格式呈现。关于字符串的操作,其实还...

忘记【分列】吧,TEXTSPLIT拆分文本好用100倍

函数TEXTSPLIT的作用是:按分隔符将字符串拆分为行或列。仅ExcelM365版本可用。基本应用将A2单元格内容按逗号拆分。=TEXTSPLIT(A2,",")第二参数设置为逗号...

Excel365版本新函数TEXTSPLIT,专攻文本拆分

Excel中字符串的处理,拆分和合并是比较常见的需求。合并,当前最好用的函数非TEXTJOIN不可。拆分,Office365于2022年3月更新了一个专业函数:TEXTSPLIT语法参数:【...

站长在线Python精讲使用正则表达式的split()方法分割字符串详解

欢迎你来到站长在线的站长学堂学习Python知识,本文学习的是《在Python中使用正则表达式的split()方法分割字符串详解》。使用正则表达式分割字符串在Python中使用正则表达式的split(...

Java中字符串分割的方法(java字符串切割方法)

技术背景在Java编程中,经常需要对字符串进行分割操作,例如将一个包含多个信息的字符串按照特定的分隔符拆分成多个子字符串。常见的应用场景包括解析CSV文件、处理网络请求参数等。实现步骤1.使用Str...

因为一个函数strtok踩坑,我被老工程师无情嘲笑了

在用C/C++实现字符串切割中,strtok函数经常用到,其主要作用是按照给定的字符集分隔字符串,并返回各子字符串。但是实际上,可不止有strtok(),还有strtok、strtok_s、strto...