服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - C语言链表实现简单图书管理系统

C语言链表实现简单图书管理系统

2022-10-18 12:00正经的民谣书生 C/C++

这篇文章主要为大家详细介绍了C语言链表实现简单图书管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文为大家分享了C语言链表实现图书管理系统的具体代码,供大家参考。

实现功能:

用C语言制作图书管理系统,实现图书进行登记书籍,浏览书籍,借阅书籍,归还书籍,书籍排序,删除书籍信息,查找书籍等功能。

功能展示

1.登记书籍

C语言链表实现简单图书管理系统

2.浏览书籍

C语言链表实现简单图书管理系统

3.借阅书籍

C语言链表实现简单图书管理系统

4.归还书籍

C语言链表实现简单图书管理系统

5.书籍排序

C语言链表实现简单图书管理系统

6.删除书籍

C语言链表实现简单图书管理系统

7.查找书籍

C语言链表实现简单图书管理系统

8.退出程序

C语言链表实现简单图书管理系统

代码如下

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
 
struct bookInfo
{
    char name[20];
    float price;
    int num;
};
 
struct Node  
{
    struct bookInfo data;
    struct Node* next;
};
struct Node* list = NULL;
 
struct Node* createHead()
{
    struct Node* headNode = (struct Node*)malloc(sizeof(struct Node));
    headNode->next = NULL;
    return headNode;
}
 
 
struct Node* createNode(struct bookInfo data)
{
    struct Node* newNode = (struct Node*)malloc(sizeof(struct Node));
    newNode->data = data;
    newNode->next = NULL;
    return newNode;
}
 
 
void insertNodeByhead(struct Node* headNode, struct bookInfo data)
{
    struct Node* newNode = createNode(data);
    newNode->next = headNode->next;
    headNode->next = newNode;
}
 
void deleteNodeByName(struct Node* headNode, char *bookName)
{
    struct Node* posLeftNode = headNode;
    struct Node* posNode = headNode->next;
    while (posNode != NULL && strcmp(posNode->data.name, bookName))
    {
        posLeftNode = posNode;
        posNode = posLeftNode->next;
    }
    if (posNode == NULL)
        return;
    else
    {
        printf("删除成功!\n");
        posLeftNode->next = posNode->next;
        free(posNode);
        posNode = NULL;
    }
}
struct Node* searchByName(struct Node* headNode, char* bookName)
{
    struct Node* posNode = headNode->next;
    while (posNode != NULL && strcmp(posNode->data.name, bookName))
    {
        posNode = posNode->next;
    }
    return posNode;
}
 
void printlist(struct Node* headNode)
{
    struct Node* pMove = headNode->next;
    printf("书名\t价格\t数量\t作者\t出版社\n");
    while (pMove!=NULL)
    {
        printf("%s\t%.1f\t%d\n", pMove->data.name, pMove->data.price, pMove->data.num);
        pMove = pMove->next;
    }
}
 
void makeMenu()
{
    printf("*************************************\n");
    printf("*************图书管理系统************\n");
    printf("*——————0.退出系统——————*\n");
    printf("*——————1.登记书籍——————*\n");
    printf("*——————2.浏览书籍——————*\n");
    printf("*——————3.借阅书籍——————*\n");
    printf("*——————4.归还书籍——————*\n");
    printf("*——————5.书籍排序——————*\n");
    printf("*——————6.删除书籍——————*\n");
    printf("*——————7.查找书籍——————*\n");
    printf("**************************************\n");
    printf("请输入(0 ~ 7):");
}
 
void saveInfoFile(const char* fileName, struct Node* headNode)
{
    FILE* fp = fopen(fileName, "w");    
    struct Node* pMove = headNode->next;
    while (pMove != NULL)
    {
        fprintf(fp, "%s\t%.1f\t%d\n", pMove->data.name, pMove->data.price, pMove->data.num);
        pMove = pMove->next;
    }
    fclose(fp);
}
 
void readInfoFromFile(const char* fileName, struct Node* headNode)
{
    FILE* fp = fopen(fileName, "r");
    if (fp == NULL)
    {
        fp = fopen(fileName, "w+");
    }
    struct bookInfo tempData;
    while (fscanf(fp, "%s\t%f\t%d\n", tempData.name, &tempData.price, &tempData.num) != EOF)
    {
        insertNodeByhead(list, tempData);
    }
    fclose(fp);
}
 
void bubbleSortlist(struct Node* headNode)
{
    for (struct Node* p = headNode->next; p != NULL; p = p->next)
    {
        for (struct Node* q = headNode->next; q->next != NULL; q = q->next)
        {
            if (q->data.price > q->next->data.price)
            {
                struct bookInfo tempData = q->data;
                q->data = q->next->data;
                q->next->data = tempData;
            }
        }
    }
    printlist(headNode);
}
 
void keyDown()
{
    int userKey = 0;
    struct bookInfo tempBook;
    struct Node* result = NULL;
    scanf("%d",&userKey);
    switch (userKey)
    {
    case 0:
        printf("【退出】\n");
        printf("退出成功\n");
        system("pause");
        exit(0);                  
        break;
    case 1:
        printf("【登记】\n");
        printf("输入书籍的信息(name,price,num):");
        scanf("%s%f%d", tempBook.name, &tempBook.price, &tempBook.num);
        insertNodeByhead(list, tempBook);
        saveInfoFile("bookinfo.txt", list
);
        break;
    case 2:
        printf("【浏览】\n");
        printlist(list);
        break;
    case 3:
        printf("【借阅】\n");    
        printf("请输入借阅的书名:");
        scanf("%s", tempBook.name);
        result = searchByName(list, tempBook.name);
        if (result == NULL)
        {
            printf("没有相关书籍无法借阅!\n");
        }
        else
        {
            if (result->data.num > 0)
            {
                result->data.num--;
                printf("借阅成功!\n");
            }
            else
            {
                printf("当前书籍无库存,借阅失败!\n");
            }
        }
        break;
    case 4:
        printf("【归还】\n");     
        printf("请输入归还的书名:");
        scanf("%s", tempBook.name);
        result = searchByName(list, tempBook.name);
        if (result == NULL)
        {
            printf("该书无借出记录\n");
        }
        else
        {
            result->data.num++;
            printf("书籍归还成功!\n");
        }
        break;
    case 5:
        printf("【排序】\n");
        bubbleSortlist(list);
        break;
    case 6:
        printf("【删除】\n");
        printf("请输入删除书名:");
        scanf("%s", tempBook.name);
        deleteNodeByName(list, tempBook.name);
        saveInfoFile("bookinfo.txt", list);
        break;
    case 7:
        printf("【查找】\n");
        printf("请输入要查询的书名:");
        scanf("%s", tempBook.name);
        result = searchByName(list, tempBook.name);
        if (result == NULL)
        {
            printf("未找到相关信息!\n");
        }
        else
        {
            printf("书名\t价格\t数量\t作者\t出版社\n");
            printf("%s\t%.1f\t%d\n", result->data.name, result->data.price, result->data.num);
        }
        break;
    default:
        printf("【error】\n");
        break;
    }
}
 
int main()
{
    list= createHead();
    readInfoFromFile("bookinfo.txt", list);
    while (1)
    {
        makeMenu();
        keyDown();
        system("pause");
        system("cls");
    }
    system("pause");
    return 0;
}

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

原文链接:https://blog.csdn.net/DAXIEA671025/article/details/121674500

延伸 · 阅读

精彩推荐
  • C/C++C语言数独游戏的求解方法

    C语言数独游戏的求解方法

    这篇文章主要为大家详细介绍了C语言数独游戏的求解方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    箫鼓声绝4432021-07-19
  • C/C++C语言编写Linux守护进程实例

    C语言编写Linux守护进程实例

    这篇文章主要介绍了C语言编写Linux守护进程实例,本文讲解了守护进程及其特性、守护进程的编程要点、守护进程代码实例等内容,需要的朋友可以参考下...

    C语言程序设计4972021-02-21
  • C/C++C语言递归操作用法总结

    C语言递归操作用法总结

    这篇文章主要介绍了C语言递归操作用法,结合实例形式总结分析了C语言递归操作的原理、实现技巧与相关应用,需要的朋友可以参考下...

    思齐_4802021-03-25
  • C/C++C++实现学生成绩管理系统最新版

    C++实现学生成绩管理系统最新版

    这篇文章主要为大家详细介绍了C++实现学生成绩管理系统最新版,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    名名名名10052021-11-16
  • C/C++C语言行优先和列优先的问题深入分析

    C语言行优先和列优先的问题深入分析

    这篇文章主要介绍了C语言行优先和列优先的问题深入分析的相关资料,需要的朋友可以参考下...

    C语言中文网9582021-04-25
  • C/C++基于C++实现读取指定路径文件

    基于C++实现读取指定路径文件

    这篇文章主要介绍了基于C++实现读取指定路径文件,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参...

    ttweixiao99995592021-09-17
  • C/C++深入讲解C语言编程中volatile修饰符的作用

    深入讲解C语言编程中volatile修饰符的作用

    这篇文章主要介绍了C语言编程中volatile修饰符的作用,文章深入到内存优化方面进行解析,非常推荐!需要的朋友可以参考下...

    bigloomy1952020-12-23
  • C/C++详解C++中的增量运算符++和减量运算符--的用法

    详解C++中的增量运算符++和减量运算符--的用法

    这篇文章主要介绍了C++中的增量运算符++和减量运算符--的用法,分为前缀情况和后缀情况来讲,需要的朋友可以参考下...

    C++教程网7762021-03-19