网站大量收购闲置独家精品文档,联系QQ:2885784924

第3章栈和队列(1794KB).ppt

  1. 1、本文档共112页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
* * * * * * * * * * * * * * * * * * * * * * * * 在日常生活中经常会遇到为了维护社会正常秩序而需要排队的情境,在计算机程序设计中也经常出现类似问题。数据结构队列与生活中的排队极为相似,也是按先到先办的原则行事的,并且严格限定:既不允许加塞儿,也不允许中途离队。    * 队列类型中的九个基本操作恰好和栈的九个操作是一一对应的。同样要求熟练掌握。 * 用一组地址连续的空间实现。用数组。 * * * * * * * * * * * * * * * Page * 数据结构设计:链式队列的结点结构体定义如下: typedef struct node { int id; //打印任务标识号 char *text; //要打印的内容 struct node *next; //指向下一个结点的指针 }Task; //结点结构体Task 链式队列的头指针、尾指针结构体定义如下: typedef struct { Task *front; //头指针 Task *rear; //尾指针 }Queue; //链式队列结构体}Queue * Page * (2)入队列。把新的打印任务加入到队尾。 void AppendPrintTask(Queue *taskmanager, int tid, char *text) //打印任务包括打印任务标识号tid和要打印的内容text { Task *p; p = (Task *) malloc(sizeof(Task)); p-text = (char *) malloc(strlen(text) * sizeof(Task) +1); strcpy(p-text, text); p-id = tid; p-next = NULL; if(taskmanager-rear != NULL) taskmanager-rear-next = p; taskmanager-rear = p; if(taskmanager-front == NULL) taskmanager-front = p; } * Page * (3)出队列。 int PrintFirstTask(Queue *taskmanager) //取出队列taskmanager中的第一个打印任务进行打印,并把该打印任务从队头删除 { Task *p = taskmanager-front; if(p == NULL) return 0; else { printf(Task id: %d\n, p-id); printf(Task context: %s\n, p-text); } taskmanager-front = taskmanager-front-next; if(taskmanager-front == NULL) taskmanager-rear = NULL; free(p-text); free(p); return 1; } 3.4 优先级队列 1、优先级队列  带有优先级的队列。 2、顺序优先级队列 用顺序存储结构存储的优先级队列。 3、优先级队列和一般队列的主要区别   优先级队列的出队列操作不是把队头元素出队列,而是把队列中优先级最高的元素出队列。 * Page * * Page * 它的数据元素定义为如下结构体: struct DataType { ElemType elem; //数据元素 int priority; //优先级 }; 注:顺序优先级队列除出队列操作外的其他操作的实现方法与前边讨论的顺序队列操作的实现方法相同。 * Page * 出队列操作(把优先级最高的元素出队列并由函数返回,优先级相同时按先进先出的原则出队列。取顺序优先队列中优先级最高的元素算法类同) 出队列算法如下: int QueueDelete(SeqPQueue *Q, DataType *d) {

文档评论(0)

精品课件 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档