【C语言 】C语言 学生选课系统(源码+论文)【独一无二】

简介: 【C语言 】C语言 学生选课系统(源码+论文)【独一无二】

一、设计要求

这段代码实现了一个学生选课系统,具有以下功能点:

1.添加课程

  • 功能描述:允许用户添加新的课程。
  • 操作步骤:用户输入课程编号和课程名称。
  • 限制条件:最多可以添加100门课程,超出后提示无法添加。

2.添加学生

  • 功能描述:允许用户添加新的学生。
  • 操作步骤:用户输入学生编号和学生姓名。
  • 限制条件:最多可以添加100名学生,超出后提示无法添加。

3.选课

  • 功能描述:允许学生选择课程。
  • 操作步骤:用户输入学生编号和课程编号。
  • 功能细节:系统会检查学生是否已选该课程,若已选则提示不能重复选择。

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 选课 ” 获取,拿来即用。👈👈👈


4.退选

  • 功能描述:允许学生退选已选择的课程。
  • 操作步骤:用户输入学生编号和课程编号。
  • 功能细节:系统会检查学生是否选了该课程,若未选则提示无法退选。


5.查询课程

  • 功能描述:查询某个学生已选的课程。
  • 操作步骤:用户输入学生编号。
  • 功能细节:系统会列出该学生已选的所有课程及其编号和名称。

6.退出

  • 功能描述:退出系统。
  • 操作步骤:用户选择退出选项。

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 选课 ” 获取,拿来即用。👈👈👈


二、设计思路

本学生选课系统的设计思路以简洁、易用为原则,主要包括以下几个部分:课程管理、学生管理、选课功能、退课功能、课程查询功能及主菜单操作。我们将使用结构体来定义课程和学生的信息,通过数组存储多个课程和学生,并实现基本的控制台输入输出操作。


1.结构体定义

首先,我们定义了两个结构体:Course 和 Student。Course 结构体包含课程编号和课程名称;Student 结构体包含学生编号、学生姓名、已选课程列表和已选课程数量。这两个结构体用于存储课程和学生的基本信息。

typedef struct {
    int courseId;
    char courseName[100];
} Course;

typedef struct {
    int studentId;
    char studentName[100];
    int enrolledCourses[MAX_COURSES];
    int enrolledCount;
} Student;


  1. 全局变量

接下来,我们定义了存储课程和学生信息的全局数组,以及记录课程和学生数量的全局变量。每个数组最多可以存储100个课程和学生。

ourse courses[MAX_COURSES];
Student students[MAX_STUDENTS];
int courseCount = 0;
int studentCount = 0;

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 选课 ” 获取,拿来即用。👈👈👈


  1. 添加课程功能

addCourse 函数用于添加新的课程。首先检查课程数量是否已满,然后提示管理员输入课程编号和名称,并将新课程添加到课程数组中。


void addCourse() {
    if (courseCount >= MAX_COURSES) {
        printf("课程已满,无法添加新课程。\n");
        return;
    }
    printf("请输入课程编号: ");
    scanf("%d", &courses[courseCount].courseId);
    
    // 略....(至少10行代码)
}


  1. 添加学生功能

addStudent 函数用于添加新的学生。首先检查学生数量是否已满,然后提示管理员输入学生编号和姓名,并将新学生添加到学生数组中。


void addStudent() {
    if (studentCount >= MAX_STUDENTS) {
        printf("学生人数已满,无法添加新学生。\n");
        return;
    }
    printf("请输入学生编号: ");
    scanf("%d", &students[studentCount].studentId);
    printf("请输入学生姓名: ");
    
    // 略....(至少10行代码)
    
    studentCount++;
    printf("学生添加成功!\n");
}

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 选课 ” 获取,拿来即用。👈👈👈


  1. 选课功能

enrollCourse 函数用于学生选课。首先提示用户输入学生编号和课程编号,然后查找相应的学生和课程,并将课程添加到学生的已选课程列表中。如果学生已选该课程,则提示重复选课信息。


void enrollCourse() {
    int studentId, courseId;
    printf("请输入学生编号: ");
    scanf("%d", &studentId);
    printf("请输入课程编号: ");
    scanf("%d", &courseId);

    Student *student = NULL;
    for (int i = 0; i < studentCount; i++) {
        if (students[i].studentId == studentId) {
            student = &students[i];
            break;
        }
    }
    // 略....(至少10行代码)
    student->enrolledCourses[student->enrolledCount] = courseId;
    student->enrolledCount++;
    printf("课程选择成功!\n");
}


  1. 退选功能

dropCourse 函数用于学生退选课程。首先提示用户输入学生编号和课程编号,然后查找相应的学生和课程,并将课程从学生的已选课程列表中移除。如果学生未选该课程,则提示错误信息。


void dropCourse() {
    int studentId, courseId;
    printf("请输入学生编号: ");
    scanf("%d", &studentId);
    printf("请输入课程编号: ");
    scanf("%d", &courseId);

    Student *student = NULL;
    for (int i = 0; i < studentCount; i++) {
        if (students[i].studentId == studentId) {
            student = &students[i];
            break;
        }
    }
    // 略....(至少10行代码)

    if (!found) {
        printf("该学生未选此课程。\n");
    }
}

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 选课 ” 获取,拿来即用。👈👈👈


  1. 查询课程功能

queryCourses 函数用于查询学生已选课程。首先提示用户输入学生编号,然后查找相应的学生,并显示该学生已选的所有课程信息。


void queryCourses() {
    int studentId;
    printf("请输入学生编号: ");
    scanf("%d", &studentId);

    Student *student = NULL;
    for (int i = 0; i < studentCount; i++) {
        if (students[i].studentId == studentId) {
            student = &students[i];
    // 略....(至少10行代码)
}

三、可视化分析



👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 选课 ” 获取,拿来即用。👈👈👈





👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 选课 ” 获取,拿来即用。👈👈👈

相关文章
|
2月前
|
存储 安全 数据管理
C语言之考勤模拟系统平台(千行代码)
C语言之考勤模拟系统平台(千行代码)
62 4
|
1月前
|
IDE 编译器 开发工具
【C语言】全面系统讲解 `#pragma` 指令:从基本用法到高级应用
在本文中,我们系统地讲解了常见的 `#pragma` 指令,包括其基本用法、编译器支持情况、示例代码以及与传统方法的对比。`#pragma` 指令是一个强大的工具,可以帮助开发者精细控制编译器的行为,优化代码性能,避免错误,并确保跨平台兼容性。然而,使用这些指令时需要特别注意编译器的支持情况,因为并非所有的 `#pragma` 指令都能在所有编译器中得到支持。
115 41
【C语言】全面系统讲解 `#pragma` 指令:从基本用法到高级应用
|
29天前
|
存储 编译器 C语言
【C语言】C语言的变量和声明系统性讲解
在C语言中,声明和定义是两个关键概念,分别用于告知编译器变量或函数的存在(声明)和实际创建及分配内存(定义)。声明可以多次出现,而定义只能有一次。声明通常位于头文件中,定义则在源文件中。通过合理组织头文件和源文件,可以提高代码的模块化和可维护性。示例包括全局变量、局部变量、函数、结构体、联合体、数组、字符串、枚举和指针的声明与定义。
52 12
|
2月前
|
机器学习/深度学习 算法 数据挖掘
C语言在机器学习中的应用及其重要性。C语言以其高效性、灵活性和可移植性,适合开发高性能的机器学习算法,尤其在底层算法实现、嵌入式系统和高性能计算中表现突出
本文探讨了C语言在机器学习中的应用及其重要性。C语言以其高效性、灵活性和可移植性,适合开发高性能的机器学习算法,尤其在底层算法实现、嵌入式系统和高性能计算中表现突出。文章还介绍了C语言在知名机器学习库中的作用,以及与Python等语言结合使用的案例,展望了其未来发展的挑战与机遇。
56 1
|
2月前
|
人工智能 安全 算法
基于C语言的嵌入式系统开发,涵盖嵌入式系统概述、C语言的优势、开发流程、关键技术、应用实例及面临的挑战与未来趋势。
本文深入探讨了基于C语言的嵌入式系统开发,涵盖嵌入式系统概述、C语言的优势、开发流程、关键技术、应用实例及面临的挑战与未来趋势。C语言因其高效、可移植、灵活及成熟度高等特点,在嵌入式系统开发中占据重要地位。文章还介绍了从系统需求分析到部署维护的完整开发流程,以及中断处理、内存管理等关键技术,并展望了嵌入式系统在物联网和人工智能领域的未来发展。
90 1
|
2月前
|
搜索推荐 算法 C语言
【排序算法】八大排序(下)(c语言实现)(附源码)
本文继续学习并实现了八大排序算法中的后四种:堆排序、快速排序、归并排序和计数排序。详细介绍了每种排序算法的原理、步骤和代码实现,并通过测试数据展示了它们的性能表现。堆排序利用堆的特性进行排序,快速排序通过递归和多种划分方法实现高效排序,归并排序通过分治法将问题分解后再合并,计数排序则通过统计每个元素的出现次数实现非比较排序。最后,文章还对比了这些排序算法在处理一百万个整形数据时的运行时间,帮助读者了解不同算法的优劣。
159 7
|
2月前
|
搜索推荐 算法 C语言
【排序算法】八大排序(上)(c语言实现)(附源码)
本文介绍了四种常见的排序算法:冒泡排序、选择排序、插入排序和希尔排序。通过具体的代码实现和测试数据,详细解释了每种算法的工作原理和性能特点。冒泡排序通过不断交换相邻元素来排序,选择排序通过选择最小元素进行交换,插入排序通过逐步插入元素到已排序部分,而希尔排序则是插入排序的改进版,通过预排序使数据更接近有序,从而提高效率。文章最后总结了这四种算法的空间和时间复杂度,以及它们的稳定性。
132 8
|
2月前
|
C语言
【数据结构】二叉树(c语言)(附源码)
本文介绍了如何使用链式结构实现二叉树的基本功能,包括前序、中序、后序和层序遍历,统计节点个数和树的高度,查找节点,判断是否为完全二叉树,以及销毁二叉树。通过手动创建一棵二叉树,详细讲解了每个功能的实现方法和代码示例,帮助读者深入理解递归和数据结构的应用。
152 8
|
2月前
|
C语言 Windows
C语言课设项目之2048游戏源码
C语言课设项目之2048游戏源码,可作为课程设计项目参考,代码有详细的注释,另外编译可运行文件也已经打包,windows电脑双击即可运行效果
43 1
|
2月前
|
程序员 C语言 开发者
pymalloc 和系统的 malloc 有什么区别?
pymalloc 和系统的 malloc 有什么区别?