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.退出系統

以上就是本文的全部內容,希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。

推薦閱讀: