新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
#ifndef __PLOT_H__#define __PLOT_H__#define FALSE 0#define TRUE 1#define MONEY 1 // 单价可以自己定义#define MAX_STOP 10#define MAX_PAVE 100// 存放汽车牌号typedef struct{
从网站建设到定制行业解决方案,为提供做网站、网站制作服务体系,各种行业企业客户提供网站建设解决方案,助力业务快速发展。创新互联建站将不断加快创新步伐,提供优质的建站服务。
int time1; // 进入停车场时间
int time2; // 离开停车场时间
char plate[10];
// 汽车牌照号码,定义一个字符指针类型}Car;// 停放栈typedef struct{
Car Stop[MAX_STOP-1]; // 各汽车信息的存储空间
int top; // 用来指示栈顶位置的静态指针}Stopping;// 等候队列typedef struct{ int count; // 用来指示队中的数据个数
Car Pave[MAX_PAVE-1]; // 各汽车信息的存储空间
int front, rear; // 用来指示队头和队尾位置的静态指针}Pavement;// 让路栈typedef struct{
Car Help[MAX_STOP-1]; // 各汽车信息的存储空间
int top; // 用来指示栈顶位置的静态指针}Buffer;
Stopping s;
Pavement p;
Buffer b;
Car c;char C[10];void stop_pave (); // 车停入便道void car_come (); // 车停入停车位void stop_to_buff (); // 车进入让路栈void car_leave (); // 车离开void welcome (); // 主界面函数void Display (); // 显示车辆信息#endif123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
源文件 PLot.c
#include "PLot.h"#include stdio.h#include time.h // 包含时间函数的头文件#include string.h#include stdlib.hvoid stop_to_pave() // 车停入便道{ // 判断队满
if (p.count 0 (p.front == (p.rear + 1) % MAX_PAVE))
{ printf ("便道已满,请下次再来\n");
} else
{ strcpy(p.Pave[p.rear].plate, C);
p.rear = (p.rear + 1) % MAX_PAVE; // 队尾指示器加1
p.count++; // 计数器加1
printf ("牌照为%s的汽车停入便道上的%d的位置\n", C, p.rear);
}
}void car_come() // 车停入停车位{ printf ("请输入即将停车的车牌号:"); // 输入车牌号
scanf ("%s", C); if (s.top = MAX_STOP - 1) // 如果停车位已满,停入便道
{
stop_to_pave(); // 停车位-便道 函数
} else
{
s.top++; // 停车位栈顶指针加1
time_t t1; long int t = time (t1); // 标记进入停车场的时间
char* t2;
t2 = ctime (t1); // 获取当前时间
c.time1 = t; strcpy(s.Stop[s.top].plate, C); // 将车牌号登记
printf ("牌照为%s的汽车停入停车位的%d车位, 当前时间:%s\n", C, s.top + 1, t2);
} return ;
}void stop_to_buff() // 车进入让路栈{ // 停车位栈压入临时栈,为需要出栈的车辆让出道
while (s.top = 0)
{
if (0 == strcmp(s.Stop[s.top--].plate, C))
{ break;
} // 让出的车进入让路栈
strcpy(b.Help[b.top++].plate, s.Stop[s.top + 1].plate); printf ("牌照为%s的汽车暂时退出停车位\n", s.Stop[s.top + 1].plate);
}
b.top --; // 如果停车位中的车都让了道,说明停车位中无车辆需要出行
if (s.top -1)
{ printf ("停车位上无此车消息\n");
} else
{ printf ("牌照为%s的汽车从停车场开走\n", s.Stop[s.top + 1].plate);
} // 将让路栈中的车辆信息压入停车位栈
while (b.top = 0)
{ strcpy(s.Stop[++s.top].plate, b.Help[b.top--].plate); printf ("牌照为%s的汽车停回停车位%d车位\n", b.Help[b.top + 1].plate, s.top + 1);
} // 从便道中 - 停车位
while (s.top MAX_STOP-1)
{ if (0 == p.count) // 判断队列是否为空
{ break;
} // 不为空,将便道中优先级高的车停入停车位
else
{ strcpy(s.Stop[++s.top].plate, p.Pave[p.front].plate); printf ("牌照为%s的汽车从便道中进入停车位的%d车位\n", p.Pave[p.front].plate, s.top+1);
p.front = (p.front + 1) % MAX_PAVE;
p.count--;
}
}
}void car_leave() // 车离开{ printf ("请输入即将离开的车牌号:\n"); scanf ("%s", C); if (s.top 0) // 判断停车位是否有车辆信息
{ printf ("车位已空,无车辆信息!\n");
} else
{
stop_to_buff();
}
time_t t1;
long int t = time (t1);
c.time2 = t; // 标记离开停车场的时间
char* t2;
t2 = ctime (t1); // 获取当前时间
printf ("离开时间%s\n需付%ld元\n", t2, MONEY * (c.time2 - c.time1) / 10);
}void Display()
{ int i = s.top; if (-1 == i)
{ printf ("停车场为空\n");
}
time_t t1; long int t = time(t1); // 标记显示时的时间
printf ("\t车牌号\t\t\t停放时间\t\t当前所需支付金额\n"); while (i != -1)
{
printf ("\t%s\t\t%d秒\t\t\t%d元\n", s.Stop[i].plate, t - c.time1, MONEY * (t - c.time1) / 10);
i--;
}
}void welcome()
{ printf ("\t*******************目前停车场状况***********************\n"); printf ("\t停车场共有%d个车位,当前停车场共有%d辆车,等候区共有%d辆车\n", MAX_STOP, s.top+1, (p.rear + MAX_PAVE - p.front)
% MAX_PAVE); printf ("\t********************************************************\n"); printf ("\t---------------Welcome to our Car Parking---------------\n");
printf ("\t* 1.Parking *\n");
printf ("\t* 2.leaving *\n");
printf ("\t* 3.situation *\n");
printf ("\t* 4.exit *\n");
printf ("\t--------------------------------------------------------\n");
}
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
主函数 main.c
/**********************************************************
问题描述:停车场是一个能放 n 辆车的狭长通道,只有一个大门,
汽车按到达的先后次序停放。若车场满了,车要在门外的便道上等候
,一旦有车走,则便道上第一辆车进入。当停车场中的车离开时,由
于通道窄,在它后面的车要先退出,待它走后依次进入。汽车离开
时按停放时间收费。
基本功能要求:
1)建立三个数据结构分别是:停放队列,让路栈,等候队列
2)输入数据模拟管理过程,数据(入或出,车号)。
***********************************************************/#include "PLot.h"int main()
{ // 初始化
s.top = -1;
b.top = 0;
p.rear = 0;
p.count = 0;
p.front = 0; while(1)
{
system("clear");
welcome(); int i, cho;
scanf ("%d", i); if (1 == i) car_come();
if (2 == i) car_leave(); if (3 == i) Display(); if (4 == i) break;
printf ("返回请输入1\n");
scanf ("%d", cho); if (1 == cho)
{ continue;
} else
{
printf ("您的输入有误,请重新输入\n");
scanf ("%d", cho); continue;
}
} return 0;
}
1、按链表的相反顺序打印出链表中各节点的值
typedef struct _l
{
int data;
struct _l *next;
} link;
void func(link *p)
{
if(p!=NULL)
{
func(p-next);
printf("%d",p-data);
}
}
2、一个队列管理的模拟系统
typedef struct _l
{
int data;
struct _l *next;
} link;
link *tail=NULL;
//1.队列初始化
int init()
{
tail=(link *)malloc(sizeof(link));
if(tail!=NULL)
{
tail-next=tail;
return 1;
}
return 0;
}
//2.当键盘输入一个正整数时,把它作为一个队列元素入队列
int insert(int n)
{
link *p;
p=(link *)malloc(sizeof(link));
if(p==NULL)
{
return 0;
}
p-data=n;
p-next=tail-next;
tail-next=p;
return 0;
}
//3.当键盘输入一个负整数时,则队头元素出列
int delete()
{
link *p=tail,*q=p;
while(p-next!=tail)
{
q=p;p=p-next;
}
if(p==q)
{
return 0;//队列空
}
else
{
q-next=p-next;
free(p);
return 1;
}
}
//4.当键盘输入0时,退出系统
//5.每输入一个整数,输出经过队列操作后队列中的所有元素
void trans()
{
link *p=tail-next;
while(p!=tail)
{
printf("%d",p-data);
p=p-next;
}
}
int main()
{
int n;
init();
while(true)
{
scanf("%d",n);
if(n==0)
{
break;
}
else if(n0)
{
insert(n);
}
else
{
delete();
}
trans();
}
}
1、鼠标双击或者右击打开桌面上DEVc++软件,让其运行起来。
2、栈是一种应用范围广泛的数据结构,适用于各种具有“后进先出”特性的问题。
3、首先构建顺序栈的储存结构。
4、顺序栈的初始化int InitStack(SqStack S)//顺序栈的初始化。
5、入栈int Push(SqStack S,int e)//入栈{if(S.top-S.base==S.stacksize)return 0;*S.top=e;S.top++;return 1;}。
6、最后,倒序输出栈中的单词,就完成了。