- 1、本文档共112页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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) {
您可能关注的文档
- 文书工作与档案管理第三版4第四章(2632KB).ppt
- 第3章世界的居民第2节世界的人种(2695KB).ppt
- 文书工作与档案管理第三版5第五章(2360KB).ppt
- 文书工作与档案管理第三版6第六章(2699KB).ppt
- 文书工作与档案管理第三版7第七章电子文书的形成与处理(700KB).ppt
- 现代房屋构成与材料赏析10.屋顶(18904KB).ppt
- 文书工作与档案管理第三版8第八章档案的收集与鉴定(2591KB).ppt
- 第3章世界的居民第3节世界的语言与宗教(19710KB).ppt
- 文书工作与档案管理第三版9第九章档案的整理与保管(3002KB).ppt
- 现代房屋构成与材料赏析12.门窗、变形缝(9168KB).ppt
最近下载
- 小学1-6年级必背古诗词115首(A4打印版).pdf
- 校对符号及其用法.doc VIP
- 大气污染控制工程课程设计.docx VIP
- 2022小学学生寒假体育家庭作业清单方案(详细版).pdf
- 一年级100以内加减法混合练习题(A4打印).pdf VIP
- 2024年四大名著三国演义知识竞赛题库及答案(共100题).pdf
- 2024年邵阳职业技术学院单招职业技能测试题库及答案(典优).docx VIP
- 广告标识牌采购投标方案(技术标360页).docx
- CNAS-SC170:2024 信息安全管理体系认证机构认可方案.docx VIP
- GB50156-2012(2014年版) 汽车加油加气站设计与施工规范.pdf
文档评论(0)