- 1、本文档共71页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
1.什么是栈 时间用time表示,其初值为0,假设time每变化一个单位对应于实际时间1分钟。当顾客到达时,若服务窗口空闲,顾客的等待时间为0,否则等待时间为服务窗口开始为顾客服务的时间减去顾客到达的时间。可以模拟计算在时间段simutime(由程序输入)内,上述服务窗口的总服务人数(cus_num)和每个顾客平均排队所需的等待时间(aver),程序如下: #include stdlib.h #include stdio.h #define MAXSIZE 100 /*符号常量MAXSIZE表示100*/ typedef struct { int data[MAXSIZE]; int front; /*队头指针*/ int rear; /*队尾指针*/ }queue; /*新类型queue为结构体类型*/ /*队列初始化函数*/ void InitQueue(queue *q) { q-front=q-rear=0; } /*入队函数*/ void EnQueue(queue *q,int x) { if((q-rear+1) % MAXSIZE ==q-front) { printf(\n overflow!);/*队满上溢*/ exit(1); } q-data[q-rear]=x;/*新元素插入队尾*/ q-rear=(q-rear+1)%MAXSIZE; /*尾指针加1*/ } /*判断队列是否为空函数*/ int QueueEmpty(queue *q) { /*队列为空,返回1,否则返回0 */ if(q-rear==q-front) return 1; else return 0; } /*出队函数*/ int DeQueue(queue *q) { int x; if(QueueEmpty(q)) { printf(\n underflow!);/*队空下溢*/ exit(1); } x=q-data[q-front];/*取出头元素*/ q-front=(q-front+1)%MAXSIZE; /*头指针加1*/ return x; } 栈的五种基本运算是:构造一个空栈、判断栈是否为空、进栈、退栈与读栈顶元素。下面介绍相应的算法。 1)构造空栈 构造空栈是指栈的初始化即给s-top赋值-1,算法如下: void InitStack(SeqStack *s) { s-top=-1; } 2)判断栈是否为空 判断栈是否为空是指判断s-top是否等于-1,若是,则表示栈空返回1;否则返回0,算法如下: int StackEmpty(SeqStack *s) /*int可省略不要*/ { return s-top==-1; } 3) 进栈 进栈也称入栈或压栈,是指在栈顶位置插入一个新元素。操作时,首先将栈顶指针s-top 加1以指示新的栈顶位置,然后将新元素插入到栈顶指针指向的位置。 当栈顶指针已经指向存储空间的最后一个位置(即s-top==MaxSize-1)时,说明栈空间已满。向一个满栈插入元素会产生“上溢”错误,算法如下: void push(SeqStack *s,ElemType x) { /* 插入一个值为x的新元素*/ if(s-top==MaxSize-1) { printf(\n 栈已满,上溢!); exit(1); } ++s-top; /*栈顶指针加1*/ s-stack[s-top]=x; /*值为x的新元素进栈*/ } 4)出栈 出栈也称退栈,是指删除栈顶元素。操作时,首先将栈顶元素(栈顶指针指向的元素)赋给一个指定的变量,然后将栈顶指针s-top 减1。当栈顶指针为s-top==-1时,说明栈空。此时进行出栈操作会产生“下溢”错误,算法如下: ElemType pop(SeqStack *s) { if(StackEmpty(s)) { /*调用判断空栈函数若栈空则下溢!*/ printf(\n 栈已空,下溢!); exit(1); } return s-stack[s-top--]; /*返回栈顶元素,栈顶指针减1*/ } 5)读栈顶元素 读栈顶元素是指将栈顶元素赋给一个指定的变量。
您可能关注的文档
- 读书与人生-精选课件(公开).ppt
- 读写任务(议论文)概括-精选课件(公开).ppt
- 杜甫“万方多难”中成就的“诗圣”2-精选课件(公开).ppt
- 杜甫1-精选课件(公开).ppt
- 杜甫58762727-精选课件(公开).ppt
- 杜甫99732700-精选课件(公开).ppt
- 杜甫诗三首41262751-精选课件(公开).ppt
- 镀膜基础-精选课件(公开).ppt
- 端午的鸭蛋-精选课件(公开).ppt
- 短句变长-精选课件(公开).ppt
- 2024年学校党总支巡察整改专题民主生活会个人对照检查材料3.docx
- 2025年民主生活会个人对照检查发言材料(四个带头).docx
- 县委常委班子2025年专题生活会带头严守政治纪律和政治规矩,维护党的团结统一等“四个带头方面”对照检查材料四个带头:.docx
- 巡察整改专题民主生活会个人对照检查材料5.docx
- 2024年度围绕带头增强党性、严守纪律、砥砺作风方面等“四个方面”自我对照(问题、措施)7.docx
- 2025年度民主生活会领导班子对照检查材料(“四个带头”).docx
- 国企党委书记2025年度民主生活会个人对照检查材料(五个带头).docx
- 带头严守政治纪律和政治规矩,维护党的团结统一等(四个方面)存在的问题整改发言提纲.docx
- 党委书记党组书记2025年带头增强党性、严守纪律、砥砺作风方面等“四个带头”个人对照检查发言材料.docx
- 2025年巡视巡察专题民主生活会对照检查材料.docx
最近下载
- 脱氧麻黄碱技术总结.pptx
- 2024年部编新改版语文六年级上册第八单元复习课教案及单元检测题(含答.pdf
- 地理-第五章《中国的地理差异》知识点(图片版) .doc VIP
- 承诺春节不离岗承诺书.docx
- 《法律职业伦理》全套配套PPT课件(共234页PPT).pptx
- pcs221说明书国内中文版.pdf
- 高水平专业群(A档)“双高计划”中期绩效自评报告:浙江建设职业技术学院 工程造价 专业群.pdf VIP
- 麻黄碱脱氧反应乳化和油化的解决技巧.docx VIP
- JJG(沪) 47-2004 垂直螺翼式水表检定规程.pdf
- 高水平专业群(A档)“双高计划”中期绩效自评报告:湖南工业职业技术学院 数控技术 专业群.pdf VIP
文档评论(0)