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

2022-07-22 12:13:32

本文实例为大家分享了C语言实现学生信息管理系统的具体代码,供大家参考,具体内容如下#define_CRT_SECURE_NO_WARNINGS#includestdio.h#includestd...

本文实例为大家分享了C语言实现学生信息管理系统的具体代码,供大家参考,具体内容如下

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h>


//数据的设计------->学生信息抽象出
struct student
{
 char name[js20];
 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");//打印链表
www.cppcns.com  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("%sphp", 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.录入信息

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

2.浏览信息

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

3.修改信息

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

4.查找信息

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

5.删除信息

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

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

6.退出系统

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。