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

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

实现功能:

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

功能展示

1.登记书籍

2.浏览书籍

3.借阅书籍

4.归还书籍

5.书籍排序

6.删除书籍

7.查找书籍

8.退出程序

代码如下

#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;
}

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

(0)

相关推荐

  • C语言图书管理系统简洁版

    DOS界面的图书管理系统,具体内容如下 程序分为两块:管理员操作(收录图书.删除图书等)和会员操作(注册.借书.还书等): 1.管理员操作界面 2.会员操作界面 global.h头文件:(程序中只使用了一个编写的头文件,在这里存放了所有的接口函数以及需要使用到的头文件,还有结构体的定义) #include "iostream" #include "string" #include "fstream" #include "conio.h&

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

    之前参照网上的资料用链表实现了图书管理系统,包括简单的增删改查功能以及借书还书功能,我是VC6.0下写的一个控制台程序,格式参照的网上的.在动手编码之前,你需要理清自己的思路.首先,需要确定图书馆里系统中主要有那几个对象,这里我写了学生对象和图书对象.不妨在纸上写出或画出它们主要包括哪些属性以及其可能的对应关系,这里根据不同人的要求会有所不同.清楚这些之后,就可以设计学生和图书的数据结构,比如这里我用的结构体存储其信息.然后就需要考虑,我想要哪些功能,除了基本的增删改查之外,我还想要哪些功能?比

  • C语言设计图书登记系统与停车场管理系统的实例分享

    图书登记管理系统 图书登记管理系统应该具有下列功能: (1). 通过键盘输入某本图书的信息: (2) .给定图书编号,显示该本图书的信息: (3) .给定作者姓名,显示所有该作者编写的图书信息: (4) .给定出版社,显示该出版社的所有图书信息: (5) .给定图书编号,删除该本图书的信息: (6) .提供一些统计各类信息的功能. 程序完整的实现代码如下: #include "stdio.h" #include "stdlib.h" #include "s

  • C语言实现简单的图书管理系统

    本文实例为大家分享了C语言实现简单图书管理系统的具体代码,供大家参考,具体内容如下 代码: /* 课程设计项目名称:图书查询系统 作者:施瑞文 时间:2018.3.4 */ #include<stdio.h> #include<string.h> #include<windows.h> #include<conio.h> #include<stdlib.h> #define N sizeof(struct BOOK) struct BOOK //

  • C语言大作业之图书管理系统的实现详程

    目录 主要内容 概要设计 项目源码 结构体 登录界面函数 选择界面函数 操作界面函数 添加函数 查找函数 删除函数 借书管理函数 信息储存函数 还书函数 修改函数 添加借书函数 查找借书函数 借书管理函数 主函数 总结 序 时间在流去,我们在长大. 嗨,这里是狐狸~~ 今天是2022年的一月四日了,元旦小长假也过去了,新年新气象,新年新目标,我们要向前看,不要执意过去了,感谢过去,把握现在,展望未来,这是我们现在应该做的.好了,废话不多说,今天我们分享一个系统,确实也有许久没有分享过系统了,今天

  • C语言实现图书馆管理系统

    本文实例为大家分享了C语言实现图书馆管理系统的具体代码,供大家参考,具体内容如下 全部代码如下: #include <stdio.h> #include<string.h> #include<stdlib.h> #include <mysql.h> #pragma comment (lib,"libmysql.lib") //#pragma comment ( lib,"xxx.lib" ) //表示鏈接xxx.lib

  • C语言实现图书管理系统

    目前为止跟着学校进度学习C语言大概半年左右,基础学习只学到了指针,学得非常浅.说实话,起初对C语言的印象---只是一个学习计算机语言的敲门砖,对具体C语言如何应用等,非常迷茫.直到大一下半学期的高级语言设计课程之后,试过dos运行的图形化界面的完整小程序,才发现C语言的魅力. ok,废话不多说了,下面是我第二节课的作品----C语言的图书管理系统.一个简单的小程序.并非纯原创,是基于网络搜索到的"学生管理系统"改编而成的.通过直接浏览.修改一个完整的代码,我的收获颇丰.我认为这样比枯燥

  • C语言实现图书管理系统(文件数据库)

    本文实例为大家分享了C语言实现图书管理系统的具体代码,供大家参考,具体内容如下 简介 c语言的一个大作业,发上来纪念下嘿嘿.写的不是很好,很多东西都揉在一起来,不过注释写的也挺多,希望能帮到有需要的朋友. 题目要求 简单文件数据库-模拟图书馆管理系统 涉及知识点:文件读写.内存管理.结构体定义.基本数据结构.高级格式化输入输出 要求: 编写一个程序模拟图书管理系统.用户分为管理员和读者两类,分别显示不同文本格式菜单,通过菜单项对应数字进行选择.读者菜单包括借书.还书.查询等功能.管理员菜单包括图

  • C语言图书管理系统课程设计

    这是本人大一第二学期初C语言课程设计的作品,嘿嘿,本来以为已经找不到原稿了,今天无意中竟然在QQ网络硬盘中找到了当初的teta版,发布于此,以作纪念. C 源代码如下: #include<stdio.h> #include<stdlib.h> #include<string.h> struct book{ char book_name[30]; int bianhao; double price; char author[20]; char state[20]; cha

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

    本文实例为大家分享了C语言链表实现图书管理系统的具体代码,供大家参考,具体内容如下 实现功能: 用C语言制作图书管理系统,实现图书进行登记书籍,浏览书籍,借阅书籍,归还书籍,书籍排序,删除书籍信息,查找书籍等功能. 功能展示 1.登记书籍 2.浏览书籍 3.借阅书籍 4.归还书籍 5.书籍排序 6.删除书籍 7.查找书籍 8.退出程序 代码如下 #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<stdlib.h>

  • Mysql实战练习之简单图书管理系统

    目录 一.梳理功能 二.准备数据库 三.构造和数据库相关的实体类 书籍 用户 NormalUser类 四.封装数据库相关操作 数据库链接操作 针对书籍表操作 针对用户表的操作 编写主逻辑(main方法和login方法) 编写operation各种细节 添加书籍操作 借书操作 删除书籍操作 查看书籍列表操作 退出系统操作 查找书籍操作 还书操作 一.梳理功能 1.能够表示书籍信息,针对每本书来说,序号,书名,作者,价格,类型. 2.能够表示用户信息,普通用户,管理员. 3.支持的操作: 对于普通用

  • java实现简单图书管理系统

    本文实例为大家分享了java实现简单图书管理系统的具体代码,供大家参考,具体内容如下 JAVA练习的作业,题目如下: 设计一个图书管理系统类和用户类,要求具有以下功能: (1). 查询和修改图书信息.(2). 增加和删除图书信息.(3). 个人借阅信息查询.(4). 图书归还功能(5). 用户管理功能和退出程序功能(注:用户信息可以保存在内存即可) 上代码: User.java public class User {     String id;     String name;     int

  • C语言链表实现学生信息管理系统程序设计

    本文实例为大家分享了C语言链表实现学生信息管理系统的具体代码,供大家参考,具体内容如下 事先存入的数据: 菜单 创建链表并倒序输出 输出链表中的全部信息 写入信息并保存至文件中(覆盖原有文件) 随机读取 指定查找 添加信息 指定删除 特殊查找 特殊删除 退出系统 #include<iostream> #include<string.h> #include<stdlib.h> #include<iomanip> #include<fstream>

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

    目前为止跟着学校进度学习C语言大概半年左右,基础学习只学到了指针,学得非常浅.说实话,起初对C语言的印象---只是一个学习计算机语言的敲门砖,对具体C语言如何应用等,非常迷茫.直到大一下半学期的高级语言设计课程之后,试过dos运行的图形化界面的完整小程序,才发现C语言的魅力. ok,废话不多说了,下面是我第二节课的作品----C语言的图书管理系统.一个简单的小程序.并非纯原创,是基于网络搜索到的"学生管理系统"改编而成的.通过直接浏览.修改一个完整的代码,我的收获颇丰.我认为这样比枯燥

  • python实现简单图书管理系统

    用python实现一个简单的图书管理系统 ,供大家参考,具体内容如下 1.工具:PyCharm3.6 社区版 我创建了一个工程叫fairy,把解释器换成Pytnon3.6 创建一个pytnon file:图书管理系统.py 2.实现简单界面如下: """ 图书管理系统 1.查询图书 2.增加图书 3.借阅图书 4.归还图书 5.退出系统 """ 3.代码实现 # 书的属性:书名,作者,状态,位置 # 管理系统: class Book(object

  • C语言链表实现学生成绩管理系统

    目录 一.课程设计题目及内容 二.主要设计思路 三.程序源码及具体注释 (1)预处理指令 (2)类型定义 (3)函数原型 (4)main函数定义 (5)其他函数定义 四.运行示例 五.注意事项 本文实例为大家分享了C语言基于链表实现学生成绩管理系统的具体代码,供大家参考,具体内容如下 一.课程设计题目及内容 程序名称:学生成绩管理系统 功能要求:录入学生成绩,修改学生成绩,统计每个学生的总分及平均分并能根据学生的平均成绩排序,查询学生成绩,输出学生成绩单.能够保存学生成绩,实现文件的读写.界面简

随机推荐