今天小编给大家分享一下C语言实现学生信息管理系统的代码写的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。具
今天小编给大家分享一下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语言实现学生信息管理系统的代码写”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注恰卡网行业资讯频道。
本站部分文章来自网络或用户投稿,如无特殊说明或标注,均为本站原创发布。涉及资源下载的,本站旨在共享仅供大家学习与参考,如您想商用请获取官网版权,如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。