C语言之高校学生信息快速查询系统的实现

news2025/4/21 17:19:54


🌟 嗨,我是LucianaiB!

🌍 总有人间一两风,填我十万八千梦。

🚀 路漫漫其修远兮,吾将上下而求索。


C语言之高校学生信息快速查询系统的实现

目录

  1. 任务陈述与分析
    • 问题陈述
    • 问题分析
  2. 数据结构设计
    • 逻辑结构
    • 存储结构
  3. 算法设计
    • 整体设计思路
    • 模块代码实现
  4. 运行截图与说明
    • 主界面
    • 添加学生
    • 删除学生
    • 查询学生
    • 显示所有学生
    • 数据持久化
    • 退出系统
  5. 系统说明
    • 编程环境
    • 数据持久化
    • 性能优化
  6. 小结
任务陈述与分析

问题陈述
在高校环境中,随着学生数量的增加,传统的线性搜索方法在查找效率上显得力不从心。为了提高查询效率,需要设计一个能够快速响应不同查询条件的学生信息管理系统。该系统需要有效管理大量学生数据,并能够根据特定的查询条件快速定位目标信息。

问题分析
设计一个高效的学生信息查询系统需要解决以下几个关键问题:

  1. 数据结构选择:选择合适的数据结构来存储学生信息,以支持快速的增删改查操作。
  2. 查询效率:系统应能够快速响应各种查询请求,包括但不限于按学号、姓名、学院、专业等条件的查询。
  3. 用户界面:提供简洁明了的用户界面,使用户能够轻松进行查询和其他操作。
  4. 数据持久化:学生信息需要能够持久化存储,即使系统重启后也能保留数据。
  5. 性能优化:随着数据量的增加,系统性能可能会下降,需要考虑性能优化措施。
  6. 安全性:保护学生信息的安全,防止未授权访问和数据泄露。
  7. 可扩展性:系统设计应考虑未来可能的功能扩展,如增加新的查询条件或集成新的数据源。
数据结构设计

逻辑结构
学生信息的逻辑结构通过 Student 结构体定义,包含学生的基本信息和用于查询的特定信息。具体字段包括:

  • student_id:学生的唯一标识符。
  • name:学生的姓名。
  • gender:学生的性别。
  • college:学生所属的学院。
  • major:学生的专业。
  • class_name:学生所在的班级。
  • avg_score:学生的平均成绩。
typedef struct {
    char student_id[20];
    char name[50];
    char gender[10];
    char college[50];
    char major[50];
    char class_name[10];
    float avg_score;
} Student;

存储结构
系统的存储结构由以下两个主要部分组成:

  • students 数组:用于存储所有学生的信息,具有 MAX_STUDENTS 的最大容量限制。
  • student_count 变量:记录当前存储在 students 数组中的学生数量。
算法设计

整体设计思路
系统采用哈希表或平衡二叉树(如 AVL 树)作为底层数据结构,以提高查询效率。对于更复杂的数据结构,可以考虑使用关系型数据库来实现数据持久化。
在这里插入图片描述

模块代码实现

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

#define MAX_STUDENTS 1000

Student students[MAX_STUDENTS];
int student_count = 0;

void searchStudentsByCollege() {
    char college[50];
    printf("Enter college to search students: ");
    scanf("%49s", college);

    int found = 0;
    for (int i = 0; i < student_count; i++) {
        if (strcmp(students[i].college, college) == 0) {
            printf("ID: %s, Name: %s, College: %s\n", students[i].student_id, students[i].name, students[i].college);
            found++;
        }
    }

    if (!found) {
        printf("No students found in this college.\n");
    }
}

void displayAllStudents() {
    for (int i = 0; i < student_count; i++) {
        printf("ID: %s, Name: %s, College: %s\n", students[i].student_id, students[i].name, students[i].college);
    }
}

void saveToFile(const char* filename) {
    FILE *file = fopen(filename, "w");
    if (!file) {
        perror("Error opening file");
        return;
    }

    for (int i = 0; i < student_count; i++) {
        fprintf(file, "ID: %s, Name: %s, College: %s\n", students[i].student_id, students[i].name, students[i].college);
    }

    fclose(file);
    printf("Data saved successfully.\n");
}
运行截图与说明

1.主界面
在这里插入图片描述

2.加入
在这里插入图片描述

3.删除
在这里插入图片描述

4.查看信息
在这里插入图片描述

5.显示所有学生
在这里插入图片描述

6.保存
在这里插入图片描述

7.退出
C语言之高校学生信息快速查询系统的实现

系统说明
  • 编程环境:Visual Studio 2022。
  • 数据持久化:使用文件系统存储学生信息。
  • 性能优化:通过哈希表或平衡二叉树提高查询效率。
小结

本学生信息管理系统是一个用C语言编写的简单而实用的程序,旨在帮助用户管理学生数据。系统提供了以下核心功能:

  • 添加学生:用户可以输入学生的各项信息,并将其存储在内存中。
  • 删除学生:通过学生ID删除特定的学生记录。
  • 查询学生:支持按学院名称搜索学生。
  • 显示所有学生:显示所有存储在内存中的学生信息。
  • 数据持久化:将学生数据保存到文件中,确保数据不会因程序关闭而丢失。

尽管该系统提供了基本的 CRUD(创建、读取、更新、删除)操作,但它还有改进的空间,例如增加数据验证、错误处理机制、更复杂的查询功能以及用户友好的图形界面。

参考文献
  • 大厂性能优化的10大顶级方案 (万字图文史上最全)-阿里云开发者社区
  • 通过关系型数据库实现数据持久化-应用数据持久化-ArkData(方舟数据管理)-应用框架
  • 数据结构教程:初学者必备指南_慕课手记
  • AI智能客服实战详解从零到一搭建系统
  • Python语言之学生信息管理系统设计-腾讯云开发者社区-腾讯云
附录代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define MAX_MENU 100  // 定义菜单项的最大数量
#define MAX_ORDER 100 // 定义订单的最大数量

// 定义菜单项结构体
typedef struct {
    int id;            // 菜品ID
    char name[50];     // 菜品名称
    float price;       // 菜品价格
} MenuItem;

// 定义订单结构体
typedef struct {
    int order_id;      // 订单ID
    char customer_phone[20];  // 顾客电话
    char customer_name[50];    // 顾客姓名
    char address[100];         // 顾客地址
    char order_time[20];       // 订单时间
    MenuItem items[MAX_MENU]; // 订单包含的菜品列表
    int items_count;           // 订单中菜品的数量
    float total_amount;        // 订单总金额
} Order;

// 定义全局变量
MenuItem menu[MAX_MENU] = {0};
Order orders[MAX_ORDER] = {0};
int menu_count = 0;
int order_count = 0;

// 函数声明
void addMenuItem();                // 添加菜单项
void modifyMenuItem(int id);       // 修改菜单项
void displayMenu();                // 显示菜单
void placeOrder();                  // 下订单
void cancelOrder(int order_id);     // 取消订单
void searchOrderByID(int order_id); // 通过订单ID搜索订单
void searchOrderByPhone(const char *phone); // 通过电话号码搜索订单
void statistics();                  // 统计信息
void applyDiscount(float *amount);  // 应用折扣
void printOrder(const Order *order); // 打印订单详情
void clearOrder(Order *order);      // 清除订单数据

// 主函数
int main() {
    int choice;
    do {
        printf("\n1. 添加/修改菜单项\n2. 下订单\n3. 取消订单\n4. 搜索订单\n5. 统计信息\n6. 退出\n");
        printf("输入你的选择: ");
        scanf("%d", &choice);

        switch (choice) {
            case 1:
                addMenuItem();
                break;
            case 2:
                placeOrder();
                break;
            case 3:
                printf("输入要取消的订单ID: ");
                scanf("%d", &choice);
                cancelOrder(choice);
                break;
            case 4:
                printf("通过 (1) 订单ID 或 (2) 电话号码搜索: ");
                scanf("%d", &choice);
                if (choice == 1) {
                    int order_id;
                    printf("输入订单ID: ");
                    scanf("%d", &order_id);
                    searchOrderByID(order_id);
                } else if (choice == 2) {
                    char phone[20];
                    printf("输入电话号码: ");
                    scanf("%s", phone);
                    searchOrderByPhone(phone);
                }
                break;
            case 5:
                statistics();
                break;
            case 6:
                printf("退出系统.\n");
                break;
            default:
                printf("无效选择,请重新输入.\n");
        }
    } while (choice != 6);

    return 0;
}

// 添加菜单项
void addMenuItem() {
    if (menu_count >= MAX_MENU) {
        printf("菜单已满,无法添加更多菜品。\n");
        return;
    }
    printf("输入菜品ID,名称和价格: ");
    scanf("%d %49s %f", &menu[menu_count].id, menu[menu_count].name, &menu[menu_count].price);
    menu_count++;
}

// 修改菜单项
void modifyMenuItem(int id) {
    for (int i = 0; i < menu_count; i++) {
        if (menu[i].id == id) {
            printf("输入新的名称和价格: ");
            scanf("%49s %f", menu[i].name, &menu[i].price);
            return;
        }
    }
    printf("未找到菜品。\n");
}

// 显示菜单
void displayMenu() {
    printf("菜单:\n");
    for (int i = 0; i < menu_count; i++) {
        printf("%d. %s - $%.2f\n", menu[i].id, menu[i].name, menu[i].price);
    }
}

// 下订单
void placeOrder() {
    if (order_count >= MAX_ORDER) {
        printf("订单数量已达上限,无法下新订单。\n");
        return;
    }

    int item_id;
    float total = 0;
    orders[order_count].items_count = 0;
    displayMenu();

    printf("输入顾客的电话、姓名、地址和下单时间: ");
    scanf("%19s %49s %99s %19s", orders[order_count].customer_phone, orders[order_count].customer_name, orders[order_count].address, orders[order_count].order_time);

    while (1) {
        printf("输入菜品ID(0结束): ");
        scanf("%d", &item_id);
        if (item_id == 0) break;

        for (int i = 0; i < menu_count; i++) {
            if (menu[i].id == item_id) {
                if (orders[order_count].items_count < MAX_MENU) {
                    orders[order_count].items[orders[order_count].items_count++] = menu[i];
                    total += menu[i].price;
                } else {
                    printf("一个订单中不能添加超过 %d 个菜品。\n", MAX_MENU);
                    break;
                }
            }
        }
    }

    applyDiscount(&total);
    orders[order_count].total_amount = total;
    orders[order_count].order_id = order_count + 1; // 简单的订单ID生成逻辑
    printf("订单成功创建。订单ID: %d\n", orders[order_count].order_id);
    order_count++;
}

// 取消订单
void cancelOrder(int order_id) {
    for (int i = 0; i < order_count; i++) {
        if (orders[i].order_id == order_id) {
            printf("订单 %d 已取消。\n", order_id);
            clearOrder(&orders[i]); // 清除订单数据
            for (int j = i; j < order_count - 1; j++) {
                memcpy(&orders[j], &orders[j + 1], sizeof(Order));
            }
            order_count--;
            return;
        }
    }
    printf("未找到订单。\n");
}

// 通过订单ID搜索订单
void searchOrderByID(int order_id) {
    int found = 0; // 用于标记是否找到订单
    for (int i = 0; i < order_count; i++) {
        if (orders[i].order_id == order_id) {
            printOrder(&orders[i]);
            found = 1; // 标记找到订单
            break;
        }
    }
    if (!found) {
        printf("没有找到订单。\n");
    }
}

// 通过电话号码搜索订单
void searchOrderByPhone(const char *phone) {
    int found = 0; // 用于标记是否找到订单
    for (int i = 0; i < order_count; i++) {
        if (strcmp(orders[i].customer_phone, phone) == 0) {
            printOrder(&orders[i]);
            found = 1; // 标记找到订单
        }
    }
    if (!found) {
        printf("没有找到该电话号码的订单。\n");
    }
}

// 统计信息
void statistics() {
    // 示例统计信息 - 可以根据实际需求扩展
    int order_count_per_item[MAX_MENU] = {0};
    float total_revenue = 0;

    for (int i = 0; i < order_count; i++) {
        total_revenue += orders[i].total_amount;
        for (int j = 0; j < orders[i].items_count; j++) {
            int item_id = orders[i].items[j].id;
            order_count_per_item[item_id]++;
        }
    }

    printf("今日总收入: %.2f\n", total_revenue);
    for (int i = 0; i < menu_count; i++) {
        if (order_count_per_item[menu[i].id] > 0) {
            printf("%s 被订购了 %d 次。\n", menu[i].name, order_count_per_item[menu[i].id]);
        }
    }
}

// 应用折扣
void applyDiscount(float *amount) {
    if (*amount > 300) *amount *= 0.85f;
    else if (*amount > 200) *amount *= 0.9f;
    else if (*amount > 100) *amount *= 0.95f;
}

// 打印订单详情
void printOrder(const Order *order) {
    if (order == NULL) {
        printf("订单为空。\n");
        return;
    }

    // 打印订单头部信息
    printf("订单ID: %d\n", order->order_id);
    printf("顾客电话: %s\n", order->customer_phone);
    printf("顾客姓名: %s\n", order->customer_name);
    printf("地址: %s\n", order->address);
    printf("下单时间: %s\n", order->order_time);
    
    // 检查是否有订单项
    if (order->items_count == 0) {
        printf("该订单没有包含任何菜品。\n");
    } else {
        printf("订单项:\n");
        for (int i = 0; i < order->items_count; i++) {
            // 打印每个订单项的名称和价格
            printf(" - %s ($%.2f)\n", order->items[i].name, order->items[i].price);
        }
    }

    // 打印订单总金额
    printf("总金额: $%.2f\n", order->total_amount);
}
// 清除订单数据
void clearOrder(Order *order) {
    memset(order, 0, sizeof(Order));
}

嗨,我是[LucianaiB](https://lucianaib.blog.csdn.net/ “LucianaiB”)。如果你觉得我的分享有价值,不妨通过以下方式表达你的支持:👍 点赞来表达你的喜爱,📁 关注以获取我的最新消息,💬 评论与我交流你的见解。我会继续努力,为你带来更多精彩和实用的内容。

点击这里👉[LucianaiB](https://lucianaib.blog.csdn.net/ “LucianaiB”) ,获取最新动态,⚡️ 让信息传递更加迅速。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2339567.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Spring Boot 项目中发布流式接口支持实时数据向客户端推送

1、pom依赖添加 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-webflux</artifactId></dependency>2、事例代码 package com.pojo.prj.controller;import com.pojo.common.core.utils.String…

【网络篇】从零写UDP客户端/服务器:回显程序源码解析

大家好呀 我是浪前 今天讲解的是网络篇的第四章&#xff1a;从零写UDP客户端/服务器&#xff1a;回显程序源码解析 从零写UDP客户端/服务器&#xff1a;回显程序源码解析 UDP 协议特性​核心类介绍​ UDP的socket应该如何使用&#xff1a;1: DatagramSocket2: DatagramPacket回…

MATLAB 控制系统设计与仿真 - 38

多变量系统控制器设计实例1 考虑如下给出的多变量系统模型&#xff1a; 考虑混合灵敏度问题&#xff0c;引入加权矩阵&#xff1a; 设计鲁棒控制器&#xff0c;并绘制闭环系统的阶跃响应曲线及开环系统的奇异值曲线。 MATLAB代码如下&#xff1a; clear all;clc; stf(s); g1…

[密码学实战]详解gmssl库与第三方工具兼容性问题及解决方案

[密码学实战]详解gmssl库与第三方工具兼容性问题及解决方案 引言 国密算法&#xff08;SM2/SM3/SM4&#xff09;在金融、政务等领域广泛应用&#xff0c;但开发者在集成gmssl库实现SM2签名时&#xff0c;常遇到与第三方工具&#xff08;如OpenSSL、国密网关&#xff09;验证不…

【k8s系列1】一主两从结构的环境准备

环境准备 虚拟机软件准备及安装&#xff0c;这里就不详细展开了&#xff0c;可以看文章:【一、虚拟机vmware安装】 linux环境准备及下载&#xff0c;下载镜像centOS7.9&#xff0c;以前也有写过这个步骤的文章&#xff0c;可以看&#xff1a;【二、安装centOS】 开始进入正题…

【Rust 精进之路之第2篇-初体验】安装、配置与 Hello Cargo:踏出 Rust 开发第一步

系列&#xff1a; Rust 精进之路&#xff1a;构建可靠、高效软件的底层逻辑 **作者&#xff1a;**码觉客 发布日期&#xff1a; 2025-04-20 引言&#xff1a;磨刀不误砍柴工&#xff0c;装备先行&#xff01; 在上一篇文章中&#xff0c;我们一起探索了 Rust 诞生的缘由&…

腾讯旗下InstantCharacter框架正式开源 可高度个性化任何角色

目前基于学习的主题定制方法主要依赖于 U-Net 架构&#xff0c;但其泛化能力有限&#xff0c;图像质量也大打折扣。同时&#xff0c;基于优化的方法需要针对特定主题进行微调&#xff0c;这不可避免地会降低文本的可控性。为了应对这些挑战&#xff0c;我们提出了 “即时角色”…

详讲Linux下进程等待

3.进程等待 引言&#xff1a;什么是进程等待 想象有两个小伙伴&#xff0c;一个是 “大强”&#xff08;父进程 &#xff09;&#xff0c;一个是 “小强”&#xff08;子进程 &#xff09;。大强给小强安排了任务&#xff0c;比如去收集一些石头。 …

JBoss + WildFly 本地开发环境完全指南

JBoss WildFly 本地开发环境完全指南 本篇笔记主要实现在本地通过 docker 创建 JBoss 和 WildFly 服务器这一功能&#xff0c;基于红帽的禁制 EAP 版本的重新分发&#xff0c;所以我这里没办法放 JBoss EAP 的 zip 文件。WildFly 是免费开源的版本&#xff0c;可以在红帽官网找…

【网络原理】TCP协议如何实现可靠传输(确认应答和超时重传机制)

目录 一. TCP协议 二. 确定应答 三. 超时重传 一. TCP协议 1&#xff09;端口号 源端口号&#xff1a;发送方端口号目的端口号&#xff1a;接收方端口号 16位&#xff08;2字节&#xff09;端口号&#xff0c;可以表示的范围&#xff08;0~65535&#xff09; 源端口和目的…

【国家能源集团生态协作平台-注册/登录安全分析报告】

前言 由于网站注册入口容易被黑客攻击&#xff0c;存在如下安全问题&#xff1a; 暴力破解密码&#xff0c;造成用户信息泄露短信盗刷的安全问题&#xff0c;影响业务及导致用户投诉带来经济损失&#xff0c;尤其是后付费客户&#xff0c;风险巨大&#xff0c;造成亏损无底洞…

idea中导入从GitHub上克隆下来的springboot项目解决找不到主类的问题

第一步&#xff1a;删除目录下的.idea和target&#xff0c;然后用idea打开 第二步&#xff1a;如果有需要&#xff0c;idea更换jdk版本 原文链接&#xff1a;https://blog.csdn.net/m0_74036731/article/details/146779040 解决方法&#xff08;idea中解决&#xff09;&#…

【AI论文】CLIMB:基于聚类的迭代数据混合自举语言模型预训练

摘要&#xff1a;预训练数据集通常是从网络内容中收集的&#xff0c;缺乏固有的领域划分。 例如&#xff0c;像 Common Crawl 这样广泛使用的数据集并不包含明确的领域标签&#xff0c;而手动整理标记数据集&#xff08;如 The Pile&#xff09;则是一项劳动密集型工作。 因此&…

Linux操作系统--环境变量

目录 基本概念&#xff1a; 常见环境变量&#xff1a; 查看环境变量的方法&#xff1a; 测试PATH 测试HOME 和环境变量相关的命令 环境变量的组织方式&#xff1a;​编辑 通过代码如何获取环境变量 通过系统调用获取或设置环境变量 环境变量通常具有全局属性 基本概念…

Jenkins 多分支管道

如果您正在寻找一个基于拉取请求或分支的自动化 Jenkins 持续集成和交付 (CI/CD) 流水线&#xff0c;本指南将帮助您全面了解如何使用 Jenkins 多分支流水线实现它。 Jenkins 的多分支流水线是设计 CI/CD 工作流的最佳方式之一&#xff0c;因为它完全基于 git&#xff08;源代…

C语言之图像文件的属性

&#x1f31f; 嗨&#xff0c;我是LucianaiB&#xff01; &#x1f30d; 总有人间一两风&#xff0c;填我十万八千梦。 &#x1f680; 路漫漫其修远兮&#xff0c;吾将上下而求索。 图像文件属性提取系统设计与实现 目录 设计题目设计内容系统分析总体设计详细设计程序实现…

LeetCode hot 100—分割等和子集

题目 给你一个 只包含正整数 的 非空 数组 nums 。请你判断是否可以将这个数组分割成两个子集&#xff0c;使得两个子集的元素和相等。 示例 示例 1&#xff1a; 输入&#xff1a;nums [1,5,11,5] 输出&#xff1a;true 解释&#xff1a;数组可以分割成 [1, 5, 5] 和 [11] 。…

高等数学同步测试卷 同济7版 试卷部分 上 做题记录 上册期中同步测试卷 B卷

上册期中同步测试卷 B卷 一、单项选择题(本大题共5小题,每小题3分,总计15分) 1. 2. 3. 4. 5. 由f(2/n), n→∞可知 2/n→0, 即x→0. 二、填空题(本大题共5小题,每小题3分&#xff0c;总计15分) 6. 7. 8. 9. 10. 三、求解下列各题(本大题共5小…

【算法】快速排序、归并排序(非递归版)

目录 一、快速排序&#xff08;非递归&#xff09; 1.原理 2.实现 2.1 stack 2.2 partition(array,left,right) 2.3 pivot - 1 > left 二、归并排序&#xff08;非递归&#xff09; 1.原理 2.实现 2.1 gap 2.1.1 i 2*gap 2.1.2 gap * 2 2.1.3 gap < array.…

【实战中提升自己】内网安全部署之dot1x部署 本地与集成AD域的主流方式(附带MAC认证)

1 dot1x部署【用户名密码认证&#xff0c;也可以解决私接无线AP等功能】 说明&#xff1a;如果一个网络需要通过用户名认证才能访问内网&#xff0c;而认证失败只能访问外网与服务器&#xff0c;可以部署dot1x功能。它能实现的效果是&#xff0c;当内部用户输入正常的…