| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1130 人关注过本帖
标题:车辆管理系统源码
只看楼主 加入收藏
AiLi
Rank: 1
等 级:新手上路
帖 子:28
专家分:0
注 册:2006-5-23
收藏
 问题点数:0 回复次数:4 
车辆管理系统源码

本人有车辆管理系统源码。。。。有人要买源码吗?

搜索更多相关主题的帖子: 车辆管理系统 源码 
2006-09-13 17:32
miker99
Rank: 1
等 级:新手上路
帖 子:45
专家分:0
注 册:2006-9-13
收藏
得分:0 

发上来啊
....


2006-09-15 17:36
abbotpldfy
Rank: 1
等 级:新手上路
帖 子:32
专家分:0
注 册:2006-9-24
收藏
得分:0 
你只是卖原代码,是不是有点损人啊!
其实窗体设计也是很重要的啊!
2006-09-25 12:56
abbotpldfy
Rank: 1
等 级:新手上路
帖 子:32
专家分:0
注 册:2006-9-24
收藏
得分:0 

没有窗体
就像人没有了躯体的灵魂

2006-10-23 22:21
为了学好C
Rank: 1
等 级:新手上路
帖 子:52
专家分:8
注 册:2010-4-3
收藏
得分:0 
#include <stdio.h>
#include <malloc.h>
#define N 3                    //停车场内最多的停车数
#define M 4                    //候车场内最多的停车数
#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);
}
int Push(SqStack *&s,int e1,int e2)
{
    if (s->top==N-1)
        return 0;
    s->top++;
    s->CarNo[s->top]=e1;
    s->CarTime[s->top]=e2;
    return 1;
}
int Pop(SqStack *&s,int &e1,int &e2)
{
    if (s->top==-1)
        return 0;
    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=0;
}
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");
}
void main()
{
    int comm;
    int no,e1,time,e2;
    int i,j;
    SqStack *St,*St1;
    SqQueue *Qu;
    InitStack(St);
    InitStack(St1);
    InitQueue(Qu);
    do
    {
        printf("输入指令(1:到达 2:离开 3:停车场 4:候车场 0:退出):");
        scanf("%d%d%d",&comm,&no,&time);
        switch(comm)
        {
        case 1:        //汽车到达
            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:        //汽车离开
            for (i=0;i<=St->top && St->CarNo[i]!=no;i++);
            if (i>St->top)
                printf("  >>未找到该编号的汽车\n");
            else
            {
                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(comm!=0);
}
2010-04-24 21:42
快速回复:车辆管理系统源码
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.025010 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved