最近很多同学因为学校的要求,需要完成自己的那个C语言课程设计,于是就有很多人私信或者加我私聊我,问的最多的还是《学生成绩管理系统》,其实当你项目写多了你就会发现:其实各类的管理系统都离不开一个核心——链表!
是的,不管是你想要写学生成绩管理系统,宿舍管理系统、火车票管理系统亦或者还是旅游管理系统等等,都需要用的到我们的链式结构来写,那么今天呢,我们就来看看如何利用C语言链式管理系统应该如何来写!
本期分享并不是直接教大家写这个学生成绩管理系统,而是以这个为线头,引出我们的大学项目类管理系统核心——链式结构。
话不多说,我们接下来就来看看我们的本文核心——链式结构管理系统的核心源码吧!让你做到:一表在手,系统我有!
源码献上
先来看看我们的singleList.h文件的代码,这个文件实际上也就是对我们的数据进行具体的操作,当然,核心还是我们的链式结构:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
struct MM
{
char name[20];
int age;
int num;
char addr[20];
};
struct Node
{
//int data;
struct MM data;
struct Node* next;
};
//所有涉及到数据的地方都要改
struct Node* createHead()
{
struct Node* headNode = (struct Node*)malloc(sizeof(struct Node));
headNode->next = NULL;
return headNode;
}
struct Node* createNode(struct MM data)
{
struct Node * newNode = (struct Node*)malloc(sizeof(struct Node));
newNode->data = data;
newNode->next = NULL;
return newNode;
}
void insertByHead(struct Node* headNode, struct MM data)
{
struct Node* newNode = createNode(data);
newNode->next = headNode->next;
headNode->next = newNode;
}
//按查找浏览
void searchAllInfo(struct Node* headNode, char *name)
{
struct Node* pMove = headNode->next;
while (pMove != NULL)
{
//!strcmp(pMove->data.name,name)条件可以改为
//strcmp(pMove->data.name,name)==0
//!:否定 真变假 ,假变真
//!-1等于0
//计算机中非零表示成立
if (!strcmp(pMove->data.name, name))
printf("%s\t%d\t%d\t%s\n", pMove->data.name, pMove->data.age, pMove->data.num, pMove->data.addr);
pMove = pMove->next;
}
}
//按姓名查找
struct Node* searchInfo(struct Node* headNode, char *name)
{
struct Node* pMove = headNode->next;
while (pMove != NULL&&strcmp(pMove->data.name, name))
{
pMove = pMove->next;
}
return pMove; //返回NULL没有找到
}
//改为按照姓名的方式
//删除一个方式
void deleteByAppoin(struct Node* headNode, char *name)
{
struct Node* posNodeLeft = headNode;
struct Node* posNode = headNode->next;
//字符串比较+数据剥洋葱
while (posNode != NULL&&strcmp(posNode->data.name ,name))
{
posNodeLeft = posNode;
posNode = posNodeLeft->next;
}
if (posNode == NULL)
{
printf("未找到指定位置,无法删除!\n");
}
else
{
posNodeLeft->next =