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

 更新时间:2022年07月22日 17:10:19   作者:心事付流年  
这篇文章主要为大家详细介绍了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语言实现单词小助手改进版

    C语言实现单词小助手改进版

    这篇文章主要为大家详细介绍了C语言实现单词小助手的改进版,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-10-10
  • C++双目运算符+=的重载详解

    C++双目运算符+=的重载详解

    这篇文章主要介绍了详解C++编程中的双目运算符重载,是C++入门学习中的基础知识,需要的朋友可以参考下,希望能够给你带来帮助
    2021-09-09
  • 详解C++中左值与右值的概念与应用

    详解C++中左值与右值的概念与应用

    左值(Lvalue)和右值(Rvalue)是C++和其他编程语言中用来区分表达式的概念。这篇文章主要为大家详细介绍了它们的概念与应用,需要的可以参考一下
    2023-03-03
  • C语言内存的动态分配比较malloc和realloc的区别

    C语言内存的动态分配比较malloc和realloc的区别

    这篇文章主要介绍了C语言内存的动态分配比较malloc和realloc的区别,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是本文的详细内容,需要的朋友可以参考下
    2021-07-07
  • 一文详解C++中运算符的使用

    一文详解C++中运算符的使用

    这篇文章主要为大家详细介绍了C++中运算符的使用方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-05-05
  • 详解约瑟夫环问题及其相关的C语言算法实现

    详解约瑟夫环问题及其相关的C语言算法实现

    这篇文章主要介绍了详解约瑟夫环问题及其相关的C语言算法实现,也是ACM当中经常会引用到的基础题目,文中共介绍了三种C语言解答,需要的朋友可以参考下
    2015-08-08
  • C语言 实现遍历一个文件夹的所有文件

    C语言 实现遍历一个文件夹的所有文件

    这篇文章主要介绍了C语言 实现遍历一个文件夹的所有文件的相关资料,需要的朋友可以参考下
    2017-01-01
  • C语言数据结构之学生信息管理系统课程设计

    C语言数据结构之学生信息管理系统课程设计

    这篇文章主要为大家详细介绍了C语言数据结构之学生信息管理系统课程设计,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • C++实现动态绑定代码分享

    C++实现动态绑定代码分享

    对于C++动态绑定的理解,就是编译器用静态分析的方法加上虚拟函数的设计实现在程序运行时动态智能执行正确虚拟函数的技术。要彻底理解动态绑定,只需要掌握两点,一是编译器的静态编译过程,二是虚拟函数的基本知识。只要有了这两点理解,任何动态绑定的分析都是很容易的
    2015-11-11
  • C语言判断字符串长度的方法小结

    C语言判断字符串长度的方法小结

    学过C/C++的人都知道,在C/C++中并没有提供直接获取数组长度的函数,对于存放字符串的字符数组提供了一个strlen函数获取其长度,那么对于其他类型的数组如何获取他们的长度呢?本文给大家介绍了C语言判断字符串长度的方法小结,需要的朋友可以参考下
    2024-08-08

最新评论