利用线性表解决问题(停车场管理)

#include <stdio.h>

#include <malloc.h>

#define N 3                    /*停车场内最多的停车数*/

#define M 3                    /*候车场内最多的停车数*/

#define Price 2             /*每单位时间停车费用*/

typedef struct

{

    int CarNo[N];           /*车牌号*/

    int CarTime[N];         /*进场时间*/

    int top;                /*栈指针*/

} SqStack;                  /*定义顺序栈类型,用于描述停车场*/

typedef struct

{

    int CarNo[M];           /*车牌号*/

    int front,rear;         /*队首和队尾指针*/

} SqQueue;                  /*定义循环队类型,用于描述候车场*/

//顺序栈

void InitStack(SqStack *&s)

{

    s=(SqStack *)malloc(sizeof(SqStack));

    s->top=-1;

}

int StackEmpty(SqStack *s)

{  return(s->top==-1);

}

int StackFull(SqStack *s)

{

    return(s->top==N-1);

}

void Push(SqStack *&s,int e1,int e2)

{

    if (s->top==N-1)

    printf("栈已满\n");

    else{

s->top++;

    s->CarNo[s->top]=e1;

    s->CarTime[s->top]=e2;}

}

int Pop(SqStack *&s,int &e1,int &e2)

{

    if (s->top==-1) {printf("处于栈底,无法删除\n");return 0;}

    else{

e1=s->CarNo[s->top];

    e2=s->CarTime[s->top];

    s->top--;

    return 1;}

}

void DispStack(SqStack *s)

{

    int i;

    for (i=s->top; i>=0; i--)

        printf("%d ",s->CarNo[i]);

    printf("\n");

}

//循环队列

void InitQueue(SqQueue *q)

{

    q=(SqQueue *)malloc (sizeof(SqQueue));

   

    q->front=q->rear=NULL;

}

int QueueEmpty(SqQueue *q)

{

    return(q->front==q->rear);

}

int QueueFull(SqQueue *q)       

{

    return ((q->rear+1)%M==q->front);

}

int enQueue(SqQueue *q,int e)      /*入队*/

{

    if ((q->rear+1)%M==q->front)    /*队满*/

        return 0;

    q->rear=(q->rear+1)%M;

    q->CarNo[q->rear]=e;

    return 1;

}

int deQueue(SqQueue *q,int &e)     /*出队*/

{

    if (q->front==q->rear)          /*队空*/

        return 0;

    q->front=(q->front+1)%M;

    e=q->CarNo[q->front];

    return 1;

}

void DispQueue(SqQueue *q)      /*输出队中元素*/

{

    int i;

    i=(q->front+1)%M;

    printf("%d ",q->CarNo[i]);

    while ((q->rear-i+M)%M>0)

    {

        i=(i+1)%M;

        printf("%d ",q->CarNo[i]);

    }

    printf("\n");

}

int main()

{

    int order;

    int no,e1,time,e2;

    int i,j,t;

    SqStack *St,*St1;  //St是停车场,St1是在有车离开时,记录为该车移开位置的车辆

    SqQueue *Qu;   //Qu是候车场

    InitStack(St);

    InitStack(St1);

    InitQueue(Qu);

    do

    {

        printf("输入指令(1:到达 2:离开 3:显示停车场 4:显示候车场 0:退出):");

        scanf("%d",&order);

        switch(order)

        {

        case 1:     /*汽车到达*/

            printf("输入车号和时间(设车号和时间均为整数): ");

            scanf("%d %d",&no,&time);

            if (!StackFull(St))         /*停车场不满*/

            {

                Push(St,no,time);

                printf("  >>停车场位置:%d\n",St->top+1);

            }

            else                        /*停车场满*/

            {

                if (!QueueFull(Qu))     /*候车场不满*/

                {

                    enQueue(Qu,no);

                    printf("  >>候车场位置:%d\n",Qu->rear);

                }

                else

                    printf("  >>候车场已满,不能停车\n");

            }

            break;

        case 2:     /*汽车离开*/

            printf("输入车号和时间(设车号和时间均为整数): ");

            scanf("%d%d",&no,&time);

            for (i=0; i<=St->top && St->CarNo[i]!=no; i++);  //在栈中找

            if (i>St->top)

                printf("  >>未找到该编号的汽车\n");

            else

            {

                t = St->top - i;  //需要出栈的车辆数目

                for (j=0; j<t; j++)  //for (j=i; j<=St->top; j++)

                {

                    Pop(St,e1,e2);

                    Push(St1,e1,e2);        /*倒车到临时栈St1中*/

                }

                Pop(St,e1,e2);              /*该汽车离开*/

                printf("  >>%d汽车停车费用:%d\n",no,(time-e2)*Price);

                while (!StackEmpty(St1))    /*将临时栈St1重新回到St中*/

                {

                    Pop(St1,e1,e2);

                    Push(St,e1,e2);

                }

                if (!QueueEmpty(Qu))        /*队不空时,将队头进栈St*/

                {

                    deQueue(Qu,e1);

                    Push(St,e1,time);       /*以当前时间开始计费*/

                }

            }

            break;

        case 3:     /*显示停车场情况*/

            if (!StackEmpty(St))

            {

                printf("  >>停车场中的车辆:"); /*输出停车场中的车辆*/

                DispStack(St);

            }

            else

                printf("  >>停车场中无车辆\n");

            break;

        case 4:     /*显示候车场情况*/

            if (!QueueEmpty(Qu))

            {

                printf("  >>候车场中的车辆:"); /*输出候车场中的车辆*/

                DispQueue(Qu);

            }

            else

                printf("  >>候车场中无车辆\n");

            break;

        case 0:     /*结束*/

            if (!StackEmpty(St))

            {

                printf("  >>停车场中的车辆:"); /*输出停车场中的车辆*/

                DispStack(St);

            }

            if (!QueueEmpty(Qu))

            {

                printf("  >>候车场中的车辆:"); /*输出候车场中的车辆*/

                DispQueue(Qu);

            }

            break;

        default:    /*其他情况*/

            printf("  >>输入的命令错误\n");

            break;

        }

    }

    while(order!=0);

    return 0;

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
链表是一种常见的数据结构,由一系列的节点组成,每个节点包含两部分信息:数据和指针。指针指向下一个节点,这样就形成了一个链式结构。 在链表的操作中,第一关是顺序构建线性表。构建线性表的目标是按照一定的顺序将节点依次连接起来。 首先,我们需要声明一个链表数据结构,包含节点的定义和指针的定义。节点由数据和指针两个部分组成。数据部分存储着节点中的数值,指针部分指向下一个节点。 接下来,我们可以按照指定的顺序依次创建节点并连接起来。首先创建一个头节点,并将链表的头指针指向该节点。然后,根据顺序,创建第一个节点,并将头节点的指针指向第一个节点。继续依次创建其他节点,将前一个节点的指针指向当前节点,直到创建完最后一个节点。 在构建线性表的过程中,我们需要注意节点之间的指针连接,以确保链表的完整性。每次创建一个节点,都要将前一个节点的指针指向当前节点。 在构建线性表完成后,我们可以通过遍历链表来验证是否按照指定顺序构建。从头节点开始,按照指针的指向逐个输出节点中的数据,确定节点的顺序是否正确。 总之,顺序构建线性表链表操作中的第一关。通过按照指定的顺序创建节点并连接起来,我们可以构建一个完整的链表。通过遍历链表验证节点的顺序,可以确保链表的正确性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值