c语言课程设计-旅馆管理系统 基于链表

这篇博客介绍了使用C语言编写的旅馆管理系统,系统基于链表实现,具备登录、创建链表、信息增删查改、文件操作等功能。作者分享了源代码,并提供了查询、退房、保存及读取本地数据的操作流程。
摘要由CSDN通过智能技术生成

自己写的一个基础的管理系统,使用链表实现,能实现登入、建立链表、插入信息、查询信息、信息排序、信息删减、保存链表至本地和从本地数据中创建链表等功能
这里写图片描述
首先是链表的建立和节点插入,我是首先建立链表(第一次使用软件),之后的信息添加则通过添加节点实现

struct save *creat()//建立链表函数 
{   

    struct save *p1,*p2,*head;

    int n=0;

    head=NULL;

    p1=p2=(struct save *)malloc(sizeof(save));

    printf("************************************\n");

    printf("请输入入住信息:\n\n");

    printf("------------------------------------\n");   
    printf("请输入房号:\n\n");

    scanf("%d",&p1->num);
    printf("------------------------------------\n");

    printf("请输入性别:\n\n");

    scanf("%s",&p1->sex);
    printf("------------------------------------\n");
    printf("请输入姓名:\n\n");

    scanf("%s",&p1->name);
    printf("------------------------------------\n");
    printf("请输入身份证号码:\n\n");

    scanf("%s",&p1->id);
    printf("------------------------------------\n");
    printf("请输入联系电话:\n\n");

    scanf("%s",&p1->phone);
    printf("------------------------------------\n");
    printf("请输入入住时长:\n\n");

    scanf("%d",&p1->day);
    printf("------------------------------------\n");
    printf("************************************\n");
    head=p1;
    head->next=NULL;
    return head;
}
void add(struct save *head)//添加节点函数 
{
    struct save *p;
    struct save *p2;
    p2=(struct save*)malloc(sizeof(save));
    p=head;

    while(p->next!=NULL)
    {

        p=p->next;
    }
        p->next=p2;
    printf("************************************\n");
        printf("请输入入住信息:\n\n");
    printf("------------------------------------\n");
        printf("请输入房号:\n\n");

        scanf("%d",&p2->num);
    printf("----------------------------------
实验一 客房管理(链表应用实验) 定义客房链表结点结构HLink (1)实现创建客房信息链表函数void Build(HLink &H),输入(客房名称、标准价格、床位数),同时修改入住价格、入住状态为默认值,即入住价格=标准价格*80%,入住状态为”空闲”(提示:用strcpy()字符串拷贝函数)。为了提高程序调试效率,强烈建议:用文件操作来输入客房信息(客房名称、标准价格、床位数); (2)实现输出客房信息函数void Exp(HLink H),输出所有客房的客房名称、标准价格、入住价格、床位数、入住状态; (3)函数int Find(HLink &H, char *roomN)),查找房间名称为roomN的客房。 (4)实现函数void updateH(HLink &H, int beds, char *state),将床位数为beds的客房入住状态改为state。 (5)函数void Add(HLink &H),将该链表中未入住的客房入住价格均加价20%; (6)求出入住价格最高的客房函数HLink FirstH(HLink &H),该函数内return语句返回入住价格最高的客房结点指针,返回前将该结点在链表中删除; (7)函数void MoveK1(HLink &H, int k),将单链表中倒数第k个结点移到第一个结点位置,注意:严禁采用先计算链表长度n再减k(即n-k)的方法; (8)函数void ReverseN2(HLink &H),将单链表的正中间位置结点之后的全部结点倒置的功能,注意:严禁采用先计算链表长度n再除以2(即n/2)的方法; (9)函数void SortPriceL(HLink &H),按照客房(入住价格,客房名称)升序排序; (10)函数void upBed(HLink &H,int beds),创建一个【床位数为beds的新结点】(还需输入:客房名称、标准价格等信息),使链表的形态为:【头结点】->【床位数>beds的结点】->【床位数为beds的新结点】->【床位数=1则输出该客房在链表中的位置序号,否则输出该客房不存在;输出(4)~(10)处理后的链表内容,(6)还要输出入住价格最高的客房信息。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值