【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行代码)
}

三、可视化分析



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





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

相关文章
|
26天前
|
C语言
【数据结构】栈和队列(c语言实现)(附源码)
本文介绍了栈和队列两种数据结构。栈是一种只能在一端进行插入和删除操作的线性表,遵循“先进后出”原则;队列则在一端插入、另一端删除,遵循“先进先出”原则。文章详细讲解了栈和队列的结构定义、方法声明及实现,并提供了完整的代码示例。栈和队列在实际应用中非常广泛,如二叉树的层序遍历和快速排序的非递归实现等。
122 9
|
26天前
|
程序员 C语言 开发者
pymalloc 和系统的 malloc 有什么区别
pymalloc 和系统的 malloc 有什么区别
|
25天前
|
存储 搜索推荐 算法
【数据结构】树型结构详解 + 堆的实现(c语言)(附源码)
本文介绍了树和二叉树的基本概念及结构,重点讲解了堆这一重要的数据结构。堆是一种特殊的完全二叉树,常用于实现优先队列和高效的排序算法(如堆排序)。文章详细描述了堆的性质、存储方式及其实现方法,包括插入、删除和取堆顶数据等操作的具体实现。通过这些内容,读者可以全面了解堆的原理和应用。
63 16
|
21天前
|
搜索推荐 算法 C语言
【排序算法】八大排序(上)(c语言实现)(附源码)
本文介绍了四种常见的排序算法:冒泡排序、选择排序、插入排序和希尔排序。通过具体的代码实现和测试数据,详细解释了每种算法的工作原理和性能特点。冒泡排序通过不断交换相邻元素来排序,选择排序通过选择最小元素进行交换,插入排序通过逐步插入元素到已排序部分,而希尔排序则是插入排序的改进版,通过预排序使数据更接近有序,从而提高效率。文章最后总结了这四种算法的空间和时间复杂度,以及它们的稳定性。
65 8
|
21天前
|
搜索推荐 算法 C语言
【排序算法】八大排序(下)(c语言实现)(附源码)
本文继续学习并实现了八大排序算法中的后四种:堆排序、快速排序、归并排序和计数排序。详细介绍了每种排序算法的原理、步骤和代码实现,并通过测试数据展示了它们的性能表现。堆排序利用堆的特性进行排序,快速排序通过递归和多种划分方法实现高效排序,归并排序通过分治法将问题分解后再合并,计数排序则通过统计每个元素的出现次数实现非比较排序。最后,文章还对比了这些排序算法在处理一百万个整形数据时的运行时间,帮助读者了解不同算法的优劣。
59 7
|
19天前
|
C语言 Windows
C语言课设项目之2048游戏源码
C语言课设项目之2048游戏源码,可作为课程设计项目参考,代码有详细的注释,另外编译可运行文件也已经打包,windows电脑双击即可运行效果
30 1
|
25天前
|
C语言
【数据结构】二叉树(c语言)(附源码)
本文介绍了如何使用链式结构实现二叉树的基本功能,包括前序、中序、后序和层序遍历,统计节点个数和树的高度,查找节点,判断是否为完全二叉树,以及销毁二叉树。通过手动创建一棵二叉树,详细讲解了每个功能的实现方法和代码示例,帮助读者深入理解递归和数据结构的应用。
82 8
|
22天前
|
程序员 C语言 开发者
pymalloc 和系统的 malloc 有什么区别?
pymalloc 和系统的 malloc 有什么区别?
|
28天前
|
存储 C语言
【数据结构】手把手教你单链表(c语言)(附源码)
本文介绍了单链表的基本概念、结构定义及其实现方法。单链表是一种内存地址不连续但逻辑顺序连续的数据结构,每个节点包含数据域和指针域。文章详细讲解了单链表的常见操作,如头插、尾插、头删、尾删、查找、指定位置插入和删除等,并提供了完整的C语言代码示例。通过学习单链表,可以更好地理解数据结构的底层逻辑,提高编程能力。
54 4
|
28天前
|
C语言
【数据结构】双向带头循环链表(c语言)(附源码)
本文介绍了双向带头循环链表的概念和实现。双向带头循环链表具有三个关键点:双向、带头和循环。与单链表相比,它的头插、尾插、头删、尾删等操作的时间复杂度均为O(1),提高了运行效率。文章详细讲解了链表的结构定义、方法声明和实现,包括创建新节点、初始化、打印、判断是否为空、插入和删除节点等操作。最后提供了完整的代码示例。
41 0