[理学]3栈和队列.ppt

  1. 1、本文档共142页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
[理学]3栈和队列

Status DeQueue (SqQueue Q, ElemType e) { // 若队列不空,则删除Q的队头元素, // 用e返回其值,并返回OK; 否则返回ERROR if (Q.front == Q.rear) return ERROR; e = Q.base[Q.front]; Q.front = (Q.front+1) % Q.queuesize; return OK; } 共 用 栈 b1 b2 … bs … … an … a2 a1 栈2底 栈2顶 top2 栈1顶 top1 栈1底 优点: 两栈互补余缺充分利用存储空间。 #define MAXNUM 100 typedef struct{ SElemType data[MAXNUM]; int top1,top2; int nStatckSize; }ShareStack; b1 b2 … bs … … an … a2 a1 栈2底 栈2顶 top2 栈1顶 top1 栈1底 1.栈空的条件? 2.栈满的条件? Status PushStack(ShareStack S, int Which, SElemType e) { // 若栈不满,则把元素e压入由which指定的栈 if (S.top1+1 == S.top2) return OVERFLOW; if(Which == 1)//入栈1 S.data[++S.top1] = e; else//入栈2 S.data[--S.top2] = e; return OK; } 请写出出栈函数 提 纲 3.4 队列的定义和基本操作 3.5 队列的实现 3.6 例子程序分析 3.7 队列应用举例 提 纲 3.4 队列的定义和基本操作 3.5 队列的实现 3.6 例子程序分析 3.7 队列应用举例 队列应用举例 一、计算 n 行杨辉三角的值 二、“划分无冲突子集问题” 第 1 行 1 1 第 2 行 1 2 1 第 3 行 1 3 3 1 第 4 行 1 4 6 4 1 二项式系数值(杨辉三角) 设第 i-1行的值:(a[0]=0) a[1]..a[i] (a[i+1]=0) 则第 i 行的值:b[j] = a[j-1]+a[j], j=1,2,…,i+1 利用循环队列计算二项式的过程: 假设只计算三行,则队列的最大容量为 5。 do { DeQueue(Q, s); GetHead(Q, e); if (e!=0) printf (“%d”, e); EnQueue(Q, s+e); } while (e!=0); 1 1 0 0 q.front q.rear 第 1 行 1 1 第 2 行 1 2 1 第 3 行 1 3 3 1 利用循环队列计算二项式的过程: 假设只计算三行,则队列的最大容量为 5。 1 1 0 0 q.front q.rear 1 1 0 0 1 q.front q.rear 1 1 0 2 1 q.front q.rear 1 1 0 2 1 q.front q.rear 1 0 0 2 1 q.front q.rear 1 0 1 2 1 q.front q.rear 1 0 1 2 1 q.front q.rear 1 0 1 2 3 q.front q.rear 1 0 1 3 3 q.front q.rear 1 0 1 3 3 q.front q.rear do { DeQueue(Q, s); GetHead(Q, e); if (e!=0) printf (“%d”, e); EnQueue(Q, s+e); } while (e!=0); 某运动会设立 N 个比赛项目,每个运动员可以参加一至三个项目。试问如何安排比赛日程既可以使同一运动员参加的项目不安排在同一单位时间进行,又使总的竞赛日程最短。 若将此问题抽象成数学模型,则归属于“划分子集”问题。N 个比赛项目构成一个大小为 n 的集合,有同一运动员参加的项目则抽象为“冲突”关系。 例如:某运动会设有 9 个项目: A = { 0,1,2,3,4,5,6,7,8 }, 七名运动

文档评论(0)

ipbohn97 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档