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