使用C语言实现学生信息管理系统

前言

在我们实现学生信息管理系统的过程中,我们几乎会使用到C语言最常用最重要的知识,对于刚学习完C语言的同学来说是一次很好的巩固机会,其中还牵扯到数据结果中链表的插入和删除内容。

实现学生信息管理系统

文件的创建与使用

·对于要实现一个大项目而言,我们要把函数进行分装,分装到头文件中,在.c文件中使用

#include"//头文件名"

另外对于定义函数时还可以专门的放在另一个.c文件中,便于维护,在这个小项目中当然不用这样做,不过为了养成好习惯,建议大家这样做。

头文件的使用

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

 创建存储学生信息结构体和节点信息结构体

//学生信息
typedef struct _Student
{int stuNum;char name[30];int source;
}Student;//节点信息
typedef struct _Node
{Student student;struct _Node* next;
}Node;

 系统界面的初始化

//初始化界面
void welcome()
{printf("**********************************\n");printf("*\t学生成绩管理系统\t*\n");printf("**********************************\n");printf("*\t请选择功能列表\t\t*\n");printf("**********************************\n");printf("*\t1.录入学生信息\t\t*\n");printf("*\t2.打印学生信息\t\t*\n");printf("*\t3.统计学生信息\t\t*\n");printf("*\t4.查找学生信息\t\t*\n");printf("*\t5.修改学生信息\t\t*\n");printf("*\t6.删除学生信息\t\t*\n");printf("*\t7.按成绩排序\t\t*\n");printf("*\t8.退出系统\t\t*\n");printf("**********************************\n");
}

输入学生信息

//输入学生信息
void inputStudent(Node* head)
{Node* fresh = (Node*)malloc(sizeof(Node));fresh->next = NULL;printf("请输入学生的学号、姓名、成绩:");scanf("%d %s %d", &fresh->student.stuNum, fresh->student.name, &fresh->student.source);Node* move = head;while (move->next != NULL){move = move->next;}//将学生信息插入链表尾部move->next = fresh;saveStudent(head);//学生信息持久化函数(自定义)
} 

打印学生信息

//打印学生信息
void printStudent(Node* head)
{Node* move = head->next;while (move != NULL){printf("学号:%d 姓名:%s 成绩:%d\n", move->student.stuNum, move->student.name, move->student.source);move = move->next;}//暂停程序system("pause");
//清空控制台system("cls");
}

统计学生人数

//统计学生人数
void countStudent(Node* head)
{welcome();int count = 0;Node* move = head->next;while (move != NULL){count++;move = move->next;}printf("学生的总人数为%d", count);//暂停程序system("pause");
//清空控制台system("cls");
}

查找学生信息

void findStudent(Node* head)
{welcome();int stuNum;printf("\n请输入要查找的学生的学号:");scanf("%d", &stuNum);Node* move = head->next;while (move != NULL){if (stuNum == move->student.stuNum){printf("学号:%d 姓名:%s 成绩:%d\n", move->student.stuNum, move->student.name, move->student.source);return;}move = move->next;}printf("未找到学生信息\n");//暂停程序system("pause");
//清空控制台system("cls");
}

学生信息持久化

//学生信息持久化
void saveStudent(Node* head)
{FILE* file = fopen("./stu.info", "w");if (file == NULL){printf("文件打开失败\n");return;}Node* move = head->next;while (move != NULL){if ((fwrite(&move->student, sizeof(Student), 1, file)) != 1){printf("写入失败\n");return;}move = move->next;}fclose(file);
}

读取学生信息

//读取学生信息
void loadStudent(Node* head)
{FILE* file = fopen("./stu.info", "r");if (!file){printf("没有学生文件,跳过读取\n");return;}Node* fresh = (Node*)malloc(sizeof(Node));fresh->next = NULL;Node* move = head;while (fread(&fresh->student, sizeof(Student), 1, file) == 1){move->next = fresh;move = fresh;fresh = (Node*)malloc(sizeof(Node));fresh->next = NULL;}free(fresh);fclose(file);printf("读取成功\n");
}

修改学生信息

//学生信息修改
void modifyStudent(Node* head)
{welcome();printf("请输入要修改信息学生的学号:");int stuNum;scanf("%d", &stuNum);Node* move = head->next;while (move != NULL){if (stuNum == move->student.stuNum){printf("请输入学生的姓名、成绩\n");scanf("%s %d", move->student.name, &move->student.source);saveStudent(head);printf("修改成功\n");return;}move = move->next;//暂停程序system("pause");
//清空控制台system("cls");}printf("未找到学生信息\n");
}

删除学生信息

//删除学生信息
void deleteStudent(Node* head)
{welcome();int stuNum;printf("请输入要删除学生信息的学号");scanf("%d", &stuNum);Node* move = head;while (move->next != NULL){if (move->student.stuNum == stuNum){Node* tmp = move->next;//把要删除的数据的保存的节点存放在一个临时节点中,防止前后节点丢失move->next = move->next->next;free(tmp);tmp = NULL;saveStudent(head);printf("删除成功\n");return;}move = move->next;}//暂停程序system("pause");
//清空控制台system("cls");
}

链表的删除操作

由于没学到数据结构,这个只是我浅薄的认识。

对学生成绩进行排序

//对学生成绩排序
void sortStudent(Node* head)
{welcome();Node* move = NULL;Node* save = NULL;for (Node* turn = head->next; turn->next != NULL; turn = turn->next){for (Node* move = head->next; move->next != save; move = move->next){if (move->student.source > move->next->student.source){Student temp = move->student;move->student = move->next->student;move->next->student = temp;}}save = move;//下一趟排序不用再次比较已经排序好的最大值}printStudent(head);//暂停程序system("pause");
//清空控制台system("cls");
}

冒泡排序

冒泡排序是在一趟一趟的过程中对相邻元素比较大小进行排序,例如我们进行升序排序,在每一趟的过程中,会把这一趟的最大元素排到最前面,进而进行下一趟排序,周而复始知道最后一趟的相邻元素大小符合升序排列。

在其中排序的过程中,由于在每一趟中我们会把最大数排列在随后,所以在以后的每一次排序中都不必要对上一趟排序后结果的最大值进行比较,例如:

对于这个算法的实现请看下面:

退出系统以及在main函数中调用这些函数:

int main()
{Node* head = (Node*)malloc(sizeof(Node));head->next = NULL;loadStudent(head);welcome();while(1){char c = _getch();switch (c){case '1': inputStudent(head);break;case '2':printStudent(head);break;case '3':countStudent(head);break;case '4':findStudent(head);break;case '5':modifyStudent(head);break;case '6':deleteStudent(head);break;case '7':sortStudent(head);break;case '8':printf("\n欢迎下次使用,bye-");exit(0);break;default:printf("请重新输入\n");break;}}return 0;
}

退出系统

总结

对于前面的函数实现而言,大多数代码的思路是相同的,对于学生信息的删除和成绩排序需要我们重点理解,愿与诸君共勉!

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

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

相关文章

【小技巧】Keil C51 报错“*** ERROR L107: ADDRESS SPACE OVERFLOW****

软件&#xff1a;Keil C51 C51V961版本 电脑&#xff1a;Win10 报错提示&#xff1a; compiling System.c... linking... *** ERROR L107: ADDRESS SPACE OVERFLOW SPACE: DATA SEGMENT: ?DT?LCD LENGTH: 0034H Program Size: data174.0 xdata17 code1205 Target not create…

100个投资者99个选择使用这款EA,WeTrade发现1个事实

为什么100个投资者会有99个选择使用这款EA&#xff0c;是因为这款EA能提供两个版本吗?是因为能控制风险吗?都不是&#xff0c;WeTrade发现1个事实才是这么多投资者选择的原因&#xff0c;那就是能实现100%的盈利率。 我们都知道外汇狙击手EA提供两种版本&#xff0c;分别是标…

MVC和Filter

目录 MVC和三层架构模型的联系 Filter 概念 作用 应用场景 步骤 简单入门 MVC和三层架构模型的联系 m-->model即模型是三层架构模型的业务层&#xff08;service&#xff09;和持久层(dao) v-->views即视图是三层架构模型的表现层(web) c-->controller即控制器也…

【SpringMVC】_SpringMVC项目返回HTML与JSON

目录 1. SpringMVC项目返回HTML页面 2. SpringMVC项目返回JSON 2.1 程序演示 2.2 关于响应的Content-Type 2.2.1 接口为对象 2.2.2 接口为String 2.2.3 接口为Map 本专栏已介绍&#xff1a; 返回静态页面&#xff1a; 【Spring MVC】_SpringMVC项目返回静态页面_mvc 返…

一种基于高德Web API实现沿路画面的实现

概述 本文在mapboxGL框架下&#xff0c;分享一种基于高德Web API实现沿路画面的实现。 实现效果 实现 1. 实现思路 通过点击获取路径的起点和终点&#xff1b;将多次规划路径的结果连成一条线&#xff1b;当鼠标点击回到第一个点的时候结束绘制&#xff1b;绘制结束后将路径…

写代码之前一定要提前想好思路

就和写数学题目一样&#xff0c;在做题目之前要先把思路确立下来。可能是我早年做数学的时候老是着急做题目没怎么分析过题目&#xff0c;把这个习惯不自觉地代入了代码的写入当中。习惯的养成使得我即使明白了自己的问题也依然会不断的犯错&#xff0c;看来只有刻意地提醒自己…

【MATLAB源码-第217期】基于matlab的16QAM系统相位偏移估计HOS算法仿真,对比补偿前后的星座图误码率。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 高阶统计量&#xff08;HOS&#xff09;频偏估计算法 高阶统计量&#xff08;Higher Order Statistics, HOS&#xff09;频偏估计算法是一种先进的信号处理技术&#xff0c;广泛应用于现代数字通信系统中&#xff0c;以应对…

如何快速申请免费单域名SSL证书

申请免费的单域名SSL证书通常涉及以下几个步骤&#xff0c;虽然具体细节可能会根据不同的证书颁发机构(CA)有所差异。以下是通用的申请流程&#xff1a; 1.选择证书颁发机构&#xff1a; 访问提供免费单域名SSL证书的证书颁发机构网站&#xff0c;例如JoySSL等。 2.注册账号…

全局配置-案例:配置tabBar

一、需求&#xff1a;实现如图所示的tabBar效果 二、实现步骤&#xff1a; 1.拷贝图标资源 把image文件夹拷贝到小程序项目根目录中 图片中包含-active的是选中之后的图标 图片中不包含-active的是默认图标 2.新建3个对应的tab页面 3.配置tabBar选项 &#xff08;1&#xf…

oracle tree

select * from "Test"; INSERT INTO "Test" ("id", "name", "pid") VALUES (01, 中国, 00); INSERT INTO "Test" ("id", "name", "pid") VALUES (01.01, 福建, 01); INSERT INTO…

如何找出真正的交易信号?Anzo Capital昂首资本总结7个

匕首是一种新兴的价格走势形态&#xff0c;虽然不常见&#xff0c;但具有较高的统计可靠性。它通常预示着趋势的持续发展。该模式涉及到同时参考两个不同的时间周期进行交易&#xff0c;一个是短期&#xff0c;另一个是长期&#xff0c;比如一周时间框架与一天时间框架、一天时…

看完这篇抖音小店选品秘籍!难道还愁不会选品吗?

大家好&#xff0c;我是喷火龙。 做抖音小店&#xff0c;没有什么花里胡哨的东西&#xff0c;核心就是我们的产品&#xff0c;把大部分精力用到选品上肯定是没错的。 选品之前一定要做好店铺的定位&#xff0c;确定好自己的主营类目&#xff0c;主营类目至少要占店铺产品的70…

J.搬砖【蓝桥杯】/01背包+贪心

搬砖 01背包贪心 思路&#xff1a;要让重量更小的在更前面&#xff0c;价值更大的在更后面&#xff0c;vi−wj>vj−wi viwi>vjwj 第 i 个箱子放在第 j 个箱子下面就显然更优。所以进行排序再用01背包即可。 #include<iostream> #include<algorithm> #defi…

go语言的使用方法

一.go语言的介绍 1.简介 2.应用领域 3.使用go语言的公司 4.go语言开发工具介绍 5.go语言开发环境搭建 【1】搭建Go开发环境-安装和配置SDK 基本介绍: 1).SDK的全称(Software Development Kit软件开发工具包&#xff09;2).SDK是提供给开发人员使用的&#xff0c;其中包含了…

SAP 消息号VF501科目确定期间出错

在销售开票VF02的时候&#xff0c;经常出现报错&#xff1a;“科目确定期间出错”&#xff0c;这个报错&#xff0c;目前检查步骤&#xff1a; 1、BP客户主数据&#xff0c;销售代码层数据&#xff08;销售与分销&#xff09;-开票-会计-客户科目分配组&#xff0c;要与销售订…

【UML用户指南】-02-UML的14种图

1、结构图 1、类图&#xff08;class diagram&#xff09; 展现了一组类、接口、协作和它们之间的关系。 在面向对象系统的建模中所建立的最常见的图就是类图。类图给出系统的静态设计视图。 包含主动类的类图给出系统的静态进程视图。构件图是类图的变体。 2、对象图&a…

【ONE·Git || 基本用法入门】

总言 主要内容&#xff1a;主要介绍Git中常用的指令。   PS&#xff1a;多人协作与企业开发模型使用&#xff0c;此部分内容不作博文总结。             文章目录 总言1、初识Git1.1、版本控制器1.2、git安装 2、基本操作2.1、Git本地仓库2.1.1、创建Git本地仓库&…

YOLO-10更快、更强

YOLO-10简介 主要贡献&#xff1a; 无NMS的一致双分配 YOLOv10提出了一种通过双标签分配而不用非极大值抑制NMS的策略。这种方法结合了一对多和一对一分配策略的优势&#xff0c;提高了效率并保持了性能。 高效的网络设计 轻量化分类头&#xff1a;在不显著影响性能的情况下&a…

LPDDR6带宽预计将翻倍增长:应对低功耗挑战与AI时代能源需求激增

在当前科技发展的背景下&#xff0c;低能耗问题成为了业界关注的焦点。国际能源署(IEA)近期报告显示&#xff0c;日常的数字活动对电力消耗产生显著影响——每次Google搜索平均消耗0.3瓦时&#xff08;Wh&#xff09;&#xff0c;而向OpenAI的ChatGPT提出的每一次请求则消耗2.9…

PFC基础知识1

不同负载 1.当负载是电阻时&#xff0c; 阻值固定&#xff0c;阻性负载&#xff0c;相位相同&#xff0c;并且线性度非常好 &#xff0c;输出的电流全部被利用 2.当负载有电感时&#xff0c;相位有偏差&#xff0c;电流滞后于电压90。电源需要输出电流&#xff0c;但是电感并未…