C语言基础(入门综合案例)

学生信息管理系统

  • 学员管理系统可以实现对学员的添加、全部显示、查询、修改、删除功能

  • 数据存储格式说明
    // 宏定义的常量,代表学生的最大个数
    #define NUM 100
    
    // 结构体类型 struct stu 别名为 STU
    typedef struct stu {
        char name[30];  // 姓名
        int age;        // 年龄
        char sex[5];    // 性别
    }STU;
    
    // 全局变量定义
    // 结构体数组
    STU s[NUM];  
    // 标志学生的个数,刚好为数组的下标,从0开始
    int n = 0;   
  • 示例代码
    #include <stdio.h>
    #include <string.h>
    
    // 宏定义的常量,代表学生的最大个数
    #define NUM 100
    
    // 结构体类型 struct stu 别名为 STU
    typedef struct stu {
        char name[30];  // 姓名
        int age;        // 年龄
        char sex[5];    // 性别
    }STU;
    
    // 全局变量定义
    // 结构体数组,默认有5个学生
    STU s[NUM] = {
        {"mike", 18, "男"},
        {"yoyo", 19, "女"},
        {"lily", 17, "女"},
        {"rock", 21, "男"},
        {"mary", 19, "女"}
    };  
    // 标志学生的个数,刚好为数组的下标
    int n = 5;   
    
    
    // 帮助菜单显示函数定义
    void help_menu() {
        printf("\n");
        printf("     欢迎使用本学生信息管理系统\n");
        printf("* ================================ *\n");
        printf("* 1. 添加                          *\n");
        printf("* 2. 显示                          *\n");
        printf("* 3. 查询                          *\n");
        printf("* 4. 修改                          *\n");
        printf("* 5. 删除                          *\n");
        printf("* 6. 退出                          *\n");
        printf("* ================================ *\n");
    }
    
    // 显示所有学生函数定义
    void show_all_stu() {
        printf("学生信息如下:\n");
        // 遍历每一个结构体数组元素,打印元素的成员
        for (int i = 0; i < n; i++) {
            printf("%s    %d    %s\n", s[i].name, s[i].age, s[i].sex);
        }
    }
    
    // 添加学生函数定义
    void add_stu() {
        // 判断学生个数有没有超过最大值
        if (n >= NUM) {
            printf("存储空间不够\n");
            return; // 提前终止函数,不能往下操作
        }
    
        // 打印请输入第n+1个学生提示信息
        printf("准备输入第%d个学生的信息\n", n+1);
        // 输入学生信息
        printf("请输入姓名:");
        scanf("%s", s[n].name); // name为数组名,代表数组首元素地址,无需加&
        printf("请输入年龄:");
        scanf("%d", &s[n].age);
        printf("请输入性别(男或女):");
        scanf("%s", s[n].sex);  // sex为数组名,代表数组首元素地址,无需加&
        // 学生个数+1
        n++;
    }
    
    // 查询学生所在的下标位置
    int find_stu_index(char *p) {
        // 通过姓名查询某个学生,返回这个学生的下标
        for (int i = 0; i < n; i++) {
            // 判断姓名是否相等
            if (strcmp(s[i].name, p) == 0) {
                return i;   // 返回找到学生的下标
            }
        }
    
        // 程序能执行到,说明没有找到,返回-1
        return -1;
    }
    
    // 打印找到学生的信息
    void show_one_stu() {
        // 输入需要找的学生
        printf("请输入需要找的学生姓名:");
        char name[30];
        scanf("%s", name);
        // 获取学生下标
        int i = find_stu_index(name);
        // 如果不为-1,则打印学生信息
        if (i != -1) {
            printf("%s 信息如下\n", name);
            printf("%s    %d    %s\n", s[i].name, s[i].age, s[i].sex);
        } else {
            printf("没有 %s 相关信息\n", name);
        }
    }
    
    // 修改某个学生的信息
    void modify_one_stu() {
        // 输入需要找的学生
        printf("请输入需要修改的学生姓名:");
        char name[30];
        scanf("%s", name);
        // 获取学生下标
        int i = find_stu_index(name);
        // 如果不为-1,则修改学生信息
        if (i != -1) {
            printf("学生原来的信息:\n");
            printf("%s    %d    %s\n", s[i].name, s[i].age, s[i].sex);
            printf("\n");
            printf("请输入新的学生信息:\n");
            // 输入学生信息
            printf("请输入姓名:");
            scanf("%s", s[i].name); // name为数组名,代表数组首元素地址,无需加&
            printf("请输入年龄:");
            scanf("%d", &s[i].age);
            printf("请输入性别(男或女):");
            scanf("%s", s[i].sex);  // sex为数组名,代表数组首元素地址,无需加&
            printf("信息更新成功,新信息如下:\n");
            printf("%s    %d    %s\n", s[i].name, s[i].age, s[i].sex);
        } else {
            printf("没有 %s 相关信息\n", name);
        }
    }
    
    // 删除某个学生
    void del_one_stu() {
        // 输入需要找的学生
        printf("请输入需要删除的学生姓名:");
        char name[30];
        scanf("%s", name);
        // 获取学生下标
        int i = find_stu_index(name);
        // 如果不为-1,则删除
        if (i != -1) {
            // 如果删除不是最后一个元素,把最后一个元素的位置替换到删除元素那个位置
            if (i != n-1) {
                s[i] = s[n-1];
            }
            // n需要-1
            n--;
    
            printf("%s 删除成功\n", name);
        } else {
            printf("没有 %s 相关信息\n", name);
        }
    }
        
    int main() {
        // 死循环
        while (1) {
            // 帮助菜单显示
            help_menu();
            // 输入操作数字
            printf("请输入指令数字:");
            int cmd;
            scanf("%d", &cmd);
            // printf("cmd = %d\n", cmd);
            // 选择判断
            if (cmd == 1) {
                printf("添加学生\n");
                add_stu();
            } else if ( cmd == 2) {
                printf("显示学生\n");
                show_all_stu();
            } else if ( cmd == 3) {
                printf("查询学生\n");
                show_one_stu();
            } else if ( cmd == 4) {
                printf("修改学生\n");
                modify_one_stu();
            } else if ( cmd == 5) {
                printf("删除学生\n");
                del_one_stu();
            } else if ( cmd == 6) {
                printf("退出系统\n");
                break;
            } else {
                printf("指令数字错误,请重新输入\n");
            }
        }
    
        return 0;
    }

  • 6
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值