【实战编程】学生信息管理系统:一键实现数据插入、智能排序、精准查询与成绩统计(附完整源码,即学即用!)

简介: 结构体数组是C语言中一种复合数据类型,它结合了结构体的灵活性和数组的有序集合特性,允许你定义一组具有相同结构的数据项。结构体定义了一组不同数据类型的变量集合,而结构体数组则是这种结构的连续内存块,每个元素都是该结构类型的实例。这种方式特别适合管理具有相似属性的对象集合,如学生信息、员工记录等。

 

技术讲解:

结构体数组是C语言中一种复合数据类型,它结合了结构体的灵活性和数组的有序集合特性,允许你定义一组具有相同结构的数据项。结构体定义了一组不同数据类型的变量集合,而结构体数组则是这种结构的连续内存块,每个元素都是该结构类型的实例。这种方式特别适合管理具有相似属性的对象集合,如学生信息、员工记录等。

定义结构体数组

首先,你需要定义一个结构体类型,然后声明一个该结构体类型的数组。以下是一个简单的例子,定义了一个存储学生信息的结构体数组:

C

1#include <stdio.h>
2
3// 定义一个结构体类型 Student
4typedef struct {
5    int id;       // 学生ID
6    char name[50]; // 姓名
7    float score;  // 成绩
8} Student;
9
10int main() {
11    // 声明一个包含3个元素的Student结构体数组
12    Student students[3];
13
14    // 初始化数组元素
15    students[0] = {1, "Alice", 89.5};
16    students[1] = {2, "Bob", 92.0};
17    students[2] = {3, "Charlie", 78.8};
18
19    // 访问和打印结构体数组的元素
20    for(int i = 0; i < 3; i++) {
21        printf("Student ID: %d, Name: %s, Score: %.2f\n",
22               students[i].id, students[i].name, students[i].score);
23    }
24
25    return 0;
26}

image.gif

特点与应用

  • 数据组织:结构体数组使得同类数据的组织和访问变得直观和高效,特别适合处理固定大小的同构数据集。
  • 内存布局:结构体数组在内存中是连续存储的,每个结构体成员在数组的每个元素中按照定义顺序依次排列。
  • 操作便捷:可以使用数组索引来访问和修改结构体数组中的任何一个元素,便于循环遍历和批量处理。
  • 动态分配:除了静态声明,也可以使用malloc()calloc()动态分配结构体数组的内存,根据需要增减数组大小。

代码思路:

首先应该是开始界面的制作,大家可以自行发挥~

其次开始让用户输入指令,进入不同的函数。

逻辑比较简单,相信各位小伙伴们仔细观看可以看懂,可能在代码整体逻辑上有些小伙伴们会一下子想不出来,不妨可以看看下图捋顺一下整体思路。

image.gif 编辑

这个程序里我用的结构体数组去存储学生的信息,实话说是比较不友好的,如果大家以后学习了链表可以接入此程序进行使用,这样学生信息便不怕溢出或者封顶了。

源码如下:

#include <stdio.h>
#include <strings.h>
#include <string.h>
#include <stdlib.h>
int count;
struct student
{
    int id;
    float math;
    float els;
    float lauge;
    float avg_score;
} stu[1000];
void home_page()
{
    printf("******************************************************\n");
    printf("*           学生成绩管理系统---帮助菜单              *\n");
    printf("******************************************************\n");
    printf("*                  H = 显示帮助菜单                  *\n");
    printf("*                  T = 成绩录入                      *\n");
    printf("*                  A = 计算学生平均分                *\n");
    printf("*                  L = 列出成绩表                    *\n");
    printf("*                  P = 按平时成绩由高到低            *\n");
    printf("*                  S = 按学号查询成绩                *\n");
    printf("*                  C = 清屏                          *\n");
    printf("*                  Q = 退出系统                      *\n");
    printf("******************************************************\n");
    printf("*           Copyright <C>   2023.6.17 by Liu         *\n");
    printf("******************************************************\n");
}
void Help()
{
    printf("*                  H = 显示帮助菜单                  *\n");
    printf("*                  T = 成绩录入                      *\n");
    printf("*                  A = 计算学生平均分                *\n");
    printf("*                  L = 列出成绩表                    *\n");
    printf("*                  P = 按平时成绩由高到低            *\n");
    printf("*                  S = 按学号查询成绩                *\n");
    printf("*                  C = 清屏                          *\n");
    printf("*                  Q = 退出系统                      *\n");
}
void Insert()
{
    printf("请输入同学个数:");
    scanf("%d", &count);
    int i, k = 0;
    printf("学号    英语    语文    数学\n");
    for (i = 0; i < count; i++)
    {
        stu[i].id = k;
        k++;
    }
    for (i = 0; i < count; i++)
    {
        ++stu[i].id;
        printf("%d", stu[i].id);
        scanf("%f %f %f", &stu[i].els, &stu[i].lauge, &stu[i].math);
    }
}
void Averge()
{
    if (strlen(stu) == 0)
    {
        printf("成绩表为空!请先使用命令 T 录入学生成绩。\n");
    }
    if (strlen(stu) != 0)
    {
        for (int i = 0; i < count; i++)
        {
            stu[i].avg_score = (stu[i].els + stu[i].lauge + stu[i].math) / 3;
        }
        printf("平均值已经打印完成,请用列表L进行查看.\n");
    }
}
void List_Score()
{
    if (strlen(stu) == 0)
    {
        printf("成绩表为空!请先使用命令 T 录入学生成绩。\n");
    }
    if (strlen(stu) != 0)
    {
        printf("学生成绩如下:\n");
        printf("学号    英语    语文    数学   平均分\n");
        for (int i = 0; i < count; i++)
        {
            printf("%d    %.1f    %.1f    %.1f    %.1f\n", stu[i].id, stu[i].els, stu[i].lauge, stu[i].math, stu[i].avg_score);
        }
    }
}
void Sort_Score()
{
    if (strlen(stu) == 0)
    {
        printf("成绩表为空!请先使用命令 T 录入学生成绩。\n");
    }
    if (strlen(stu) != 0)
    {
        int i, j;
        for (i = 0; i < 999; i++)
        {
            for (j = 0; j < 998 - i; j++)
            {
                if (stu[j].avg_score < stu[j + 1].avg_score)
                {
                    mun = stu[j];
                    stu[j] = stu[j + 1];
                    stu[j + 1] = mun;
                }
            }
        }
        printf("完成排序。请使用命令L查看。\n");
    }
}
void Reserch_Score()
{
    if (strlen(stu) == 0)
    {
        printf("成绩表为空!请先使用命令 T 录入学生成绩。\n");
    }
    while (1)
    {
        printf("请输入你想查询的学号:");
        int a;
        scanf("%d", &a);
        getchar();
        for (int i = 0; i < count; i++)
        {
            if (a == stu[i].id)
            {
                printf("%.1f %.1f %.1f %.1f\n", stu[i].els, stu[i].lauge, stu[i].math, stu[i].avg_score);
                break;
            }
        }
        break;
    }
}
int main(int argc, char const *argv[])
{
    home_page();
    char cmd[32];
    while (1)
    {
        printf("请输入你的指令:");
        scanf(" %c", cmd);
        // getchar();
        if (strcmp(cmd, "H") == 0)
        {
            Help();
        }
        else if (strcmp(cmd, "T") == 0)
        {
            Insert();
        }
        else if (strcmp(cmd, "A") == 0)
        {
            Averge();
        }
        else if (strcmp(cmd, "L") == 0)
        {
            List_Score();
        }
        else if (strcmp(cmd, "P") == 0)
        {
            Sort_Score();
        }
        else if (strcmp(cmd, "S") == 0)
        {
            Reserch_Score();
        }
        else if (strcmp(cmd, "C") == 0)
        {
            system("cls");
        }
        else if (strcmp(cmd, "Q") == 0)
        {
            return 0;
        }
    }
}

image.gif

相关文章
|
存储 机器学习/深度学习 监控
物联网平台常见类别及对应平台(二)
物联网平台常见类别及对应平台(二)
638 21
|
存储 JSON 物联网
设备管理组件功能介绍
设备管理组件功能介绍
640 2
|
机器学习/深度学习 数据可视化 数据挖掘
数据降维 | MATLAB实现T-SNE降维特征可视化
数据降维 | MATLAB实现T-SNE降维特征可视化
|
监控 安全 物联网
物联卡安全问题
物联卡安全性涵盖技术、管理和使用安全。技术上,通过专用通道和加密技术保障数据传输安全;管理上,实施实名认证与风险防控措施;使用中需合规操作、警惕诈骗并定期检查更新。尽管如此,仍需防范管理漏洞、诈骗及非法流量风险,确保安全运行。
|
数据可视化 定位技术 vr&ar
商场3D楼层导视软件功能详解与实施效益
**维小帮3D楼层导视软件**提供创新的商场导航体验:3D地图清晰呈现楼层布局,跨楼层导航智能规划路径;实时定位防止迷路;AR实景导航增强沉浸感;广告推送及可视化招商平台助力商业运营。软件结合VR、AR技术,优化顾客导航,促进营销,实现智慧化管理与招商,引领商场服务升级。
795 1
商场3D楼层导视软件功能详解与实施效益
|
人工智能 自然语言处理 小程序
政务VR导航:跨界融合AI人工智能与大数据分析,打造全方位智能政务服务
政务大厅引入智能导航系统,解决寻路难、指引不足及咨询台压力大的问题。VR导视与AI助手提供在线预览、VR路线指引、智能客服和小程序服务,提高办事效率,减轻咨询台工作,优化群众体验,塑造智慧政务形象。通过线上线下结合,实现政务服务的高效便民。
466 2
政务VR导航:跨界融合AI人工智能与大数据分析,打造全方位智能政务服务
|
安全 算法 小程序
院内智能导航系统赋能医院智慧化转型,加速医疗服务升级
**智慧医院的智能导航系统**是医疗数字化转型的关键,它改善患者就医体验,减轻医务人员压力,优化资源配置并强化安全监管。3D导航、AR指路、VR辅助、自动导诊和停车管理等先进技术,结合实时定位功能,确保精准、快捷的导航服务。此系统减少患者寻路时间,降低服务台咨询量,优化医院交通,增强患者安全,同时提高就医效率和医院信息化水平。
543 1
院内智能导航系统赋能医院智慧化转型,加速医疗服务升级
|
消息中间件 分布式计算 网络协议
从管道路由到共享内存:进程间通信的演变(内附通信方式经典面试题及详解)
进程间通信(Inter-Process Communication, IPC)是计算机科学中的一个重要概念,指的是运行在同一系统或不同系统上的多个进程之间互相发送和接收信息的能力。IPC机制允许进程间共享数据、协调执行流程,是实现分布式系统、多任务操作系统和并发编程的基础。
355 1
从管道路由到共享内存:进程间通信的演变(内附通信方式经典面试题及详解)
|
机器学习/深度学习 缓存 自然语言处理
采用ChatGPT大模型高效精准文档翻译
这款文档翻译工具支持PDF、Word、PPT、Excel和TXT等多种格式,利用ChatGPT大模型进行高效精准的翻译,覆盖30多种语言。它通过文档解析、预处理、翻译和结果合成步骤工作,并采用缓存、并行处理和负载均衡技术优化性能。该工具满足全球化背景下企业和个人的多语言需求,助力信息交流。
1041 1
采用ChatGPT大模型高效精准文档翻译