今天小编给大家分享一下C语言实现学生信息管理系统的代码写的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
具体代码如下
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
//数据的设计------->学生信息抽象出
struct student
{
char name[20];
int age;
char sex[5];
char tel[20];
};
//结构分结构去写
//某一种数据结构去实现什么东西的时候,单独去写一种数据结构
//先把数据结构写对了再说
struct Node
{
//int data;
struct student data;
struct Node* next;
};
//创建表
struct Node* createList()
{
//用结构体变量表示表头
//指针-->变量 动态内存申请
struct Node* headNode = (struct Node*)malloc(sizeof(struct Node));
//表头:做差异化处理 数据data不做初始化
headNode->next = NULL;
return headNode;
}
struct Node* createNode(struct student data)
{
struct Node* newNode = (struct Node*)malloc(sizeof(struct Node));
newNode->data = data;
newNode->next = NULL;
return newNode;
}
//插入结点
void insertNodeByHead(struct Node* headNode, struct student data)
{
struct Node* newNode = createNode(data);
//表头法
newNode->next = headNode->next;
headNode->next = newNode;
}
//指定位置删除
//data为struct student型,结构体,不能直接比较
void deleteAPPoinNode(struct Node* headNode, char* name)//指定姓名进行删除
{
struct Node* posNode = headNode->next;
struct Node* posFrontNode = headNode;
if (posNode == NULL)
{
printf("数据为空,无法删除!\n");
return;
}
//姓名为字符串,不能直接比较,字符串的比较为strcmp
while (strcmp(posNode->data.name,name))
{
posFrontNode = posNode;
posNode = posFrontNode->next;
if (posNode == NULL)
{
printf("未找到指定位置,无法删除!\n");
return;
}
}
//找到了
posFrontNode->next = posNode->next;
free(posNode);
}
//查找功能
struct Node* searchInfoByData(struct Node* headNode,char* name)//指定姓名查找
{
struct Node* pMove = headNode->next;
while (pMove != NULL && strcmp(pMove->data.name, name))
{
pMove = pMove->next;
}
return pMove;
}
//文件读操作(链表的存储)
void readInfoFromFile(struct Node* headNode,const char *fileName)
{
//1.打开
FILE *fp;//文件指针
struct student data;
fp = fopen(fileName, "r");//以读取方式打开
if (fp == NULL)
{
fopen(fileName, "w+");//以创建方式打开
}
//2.读文件
while (fscanf(fp, "%s\t%d\t%s\t%s\n"/*格式化形式*/, data.name, &data.age, data.sex, data.tel) != EOF/*文件结束符*/)//将文件作为输入设备,格式化读到data中
{
insertNodeByHead(headNode, data);//读过程中存放到链表
}
//3.关闭文件
fclose(fp);
}
//文件写操作(链表的读取)
void writeInfoToFile(struct Node* headNode,const char *fileName)
{
FILE *fp;
fp = fopen(fileName, "w");//以追加方式打开
if (fp == NULL)
{
printf("文件打开失败!");
return;
}
struct Node* pMove = headNode->next;
while (pMove)
{
fprintf(fp, "%s\t%d\t%s\t%s\n"/*格式化形式*/, pMove->data.name, pMove->data.age, pMove->data.sex, pMove->data.tel);
pMove = pMove->next;
}
fclose(fp);
}
//打印链表
void printfList(struct Node* headNode)
{
struct Node* pMove = headNode->next;
//涉及到数据的处理
printf("姓名\t年龄\t性别\t电话\n");
while (pMove)
{
printf("%s\t%d\t%s\t%s\n", pMove->data.name, pMove->data.age, pMove->data.sex, pMove->data.tel);
pMove = pMove->next;
}
printf("\n");
}
/*
1.界面
2.数据结构的设计
//需要和数据结构设计糅合在一起
3.交互
*/
#include "myList.h"
//菜单设计
void menu()
{
//所有操作都同步到文件
printf("-----------【学生信息管理系统】-----------\n");
printf("\t\t0.退出系统\n");
printf("\t\t1.录入信息\n");
printf("\t\t2.浏览信息\n");
printf("\t\t3.修改信息\n");
printf("\t\t4.删除信息\n");
printf("\t\t5.查找信息\n");
printf("------------------------------------------\n");
}
struct Node* list = createList();
//用户的交互
//根据所选菜单项,做相应的事情
void keyDown()
{
int choice = 0;
struct student data;
struct Node* pMove = NULL;
scanf("%d", &choice);
switch (choice)
{
case 0:
printf("正常退出!\n");
system("pause");
exit(0);
break;
case 1:
printf("---------------【录入信息】---------------\n");//插入链表
printf("请输入学生姓名年龄性别电话:");
fflush(stdin);//清空缓冲区
scanf("%s%d%s%s", data.name, &data.age, data.sex, data.tel);
insertNodeByHead(list, data);
break;
case 2:
printf("---------------【浏览信息】--------------\n");//打印链表
printfList(list);
break;
case 3:
printf("---------------【修改信息】---------------\n");
printf("需要修改信息的学生姓名:");
scanf("%s", data.name);
deleteAPPoinNode(list, data.name);
printf("请重新输入学生信息:");
fflush(stdin);
scanf("%s%d%s%s", data.name, &data.age, data.sex, data.tel);
insertNodeByHead(list, data);
break;
case 4:
printf("---------------【删除信息】---------------\n");
printf("请输入删除的学生姓名:");
scanf("%s", data.name);
deleteAPPoinNode(list,data.name);
break;
case 5:
printf("---------------【查找信息】---------------\n");
printf("请输入要查找学生姓名:");
scanf("%s", data.name);
pMove = searchInfoByData(list, data.name);
if (pMove == NULL)
{
printf("未找到相关信息,无法删除!\n");
system("pause");
}
else
{
printf("姓名\t年龄\t性别\t电话\n");
printf("%s\t%d\t%s\t%s\n", pMove->data.name, pMove->data.age, pMove->data.sex, pMove->data.tel);
}
break;
default:
printf("选择错误,重新输入\n");
system("pause");
break;
}
writeInfoToFile(list, "1.txt");//保存,调用文件写函数
}
int main()
{
readInfoFromFile(list, "1.txt");//程序运行前,调用文件读函数
while (1)
{
menu();
keyDown();
system("pause");
system("cls");
}
/*测试链表代码
struct Node* list = createList();
insertNodeByHead(list, 1);
insertNodeByHead(list, 3);
insertNodeByHead(list, 2);
insertNodeByHead(list, 5);
printfList(list);
printf("删除指定位置!\n");
deleteAPPoinNode(list, 3);
printfList(list);
printf("链表的查找:\n");
printf("%d\n",searchInfoByData(list, 5)->data);*/
system("pause");
return 0;
}
运行截图
1.录入信息
2.浏览信息
3.修改信息
4.查找信息
5.删除信息
6.退出系统
以上就是“C语言实现学生信息管理系统的代码写”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注亿速云行业资讯频道。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。