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

数据结构-使用C语言 朱战立 第3章堆栈和队列.ppt

数据结构-使用C语言 朱战立 第3章堆栈和队列.ppt

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

* * * * * (5)取队头数据元素QueueGet(Q, d) int QueueGet(LQueue Q, DataType *d) { if(Q.front == NULL) { printf(队列已空无数据元素出队列! \n); return 0; } else { *d = Q.front-data; return 1; } } 6、队列的应用 任务描述:一个计算机局域网系统中有若干台计算机,为了节约资源,只安装了一台打印机,要求设计一个对打印机的打印任务进行管理的打印任务管理器,打印机的打印任务按照先来先打印的方式进行管理。 任务分析:打印任务管理器可设计成一个链式队列。打印任务管理器应包含的操作有: (1)初始化。 (2)入队列。把新的打印任务加入到队尾。 (3)出队列。 (4)输出。 (5)清空。 任务说明:每一个打印任务应包含打印任务标识号和要打印的内容。 数据结构设计:链式队列的结点结构体定义如下: typedef struct node { int id; //打印任务标识号 char *text; //要打印的内容 struct node *next; //指向下一个结点的指针 }Task; //结点结构体Task 链式队列的头指针、尾指针结构体定义如下: typedef struct { Task *front; //头指针 Task *rear; //尾指针 }Queue; //链式队列结构体}Queue (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; } (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; } 练习 void main(){ QueueInitiate(Q); char x=e,y=c; QueueAppend(Q,h);QueueAppend(Q,r);QueueAppend(Q,y); QueueDelete(Q,x);QueueAppend(Q,x); QueueDelete(Q,x);QueueAppend(Q,a); while(!QueueNotEmpty(Q)){ QueueDelete(Q,y); printf(y); } printf(x); } * void algo(Queue Q){ int d; StackInitiate(S); while(!QueueNotEmpty

文档评论(0)

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

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

1亿VIP精品文档

相关文档