如何用C语言编写一个支持长尾词查询的学生信息管理系统?

2026-04-12 09:111阅读0评论SEO问题
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1302个文字,预计阅读时间需要6分钟。

如何用C语言编写一个支持长尾词查询的学生信息管理系统?

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

如何用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.退出系统

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

本文共计1302个文字,预计阅读时间需要6分钟。

如何用C语言编写一个支持长尾词查询的学生信息管理系统?

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

如何用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.退出系统

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