- 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
最近下载
- 第一章 2.2 水量平衡.ppt
- 《GB/T 19326-2022锻制支管座》.pdf
- 2022年11月陕西省从优秀村社区干部中考试录用200名乡镇街道机关公务员上岸冲刺卷I含答案详解版(3套).docx VIP
- 2020年银行业从业人员职业操守和行为准则.pdf VIP
- 转预备党员思想汇报【银行】.pdf VIP
- 【新教材】人教版(2024)七年级上册英语Unit 4 My Favourite Subject教案.docx
- 米厂恒温仓库工程设计方案.docx
- 2024年党校入党积极分子培训考试必考重点知识汇编(共160题).doc VIP
- 《世界经典神话与传说故事》 测试题及答案.pdf
- 智能制造设备安装与调试职业技能等级标准(2021年).pdf
文档评论(0)