队列的链式存储结构-创新互联
由于线性存储结构有顺序存储和链式存储两种,而队列是一种特殊的线性结构,所以,队列自然也会有链式存储结构,这种存储结构,称之为“链队列”。只不过,这种结构需要两个指针,一个指针指向队列的头部,一个指针指向队列的尾部。虽然队列采用了链式存储这种方式,但是它本质上仍然是队列,因此,只要是队列,就要遵循:只允许在队列的头部进行删除操作,只允许在队里的尾部进行插入操作。那么,先来定义个链队列结构:
专注于为中小企业提供成都做网站、成都网站建设服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业濮阳县免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了近千家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。typedef int QElemType; typedef struct QNode{ QElemType data; struct QNode *next; }QNode, *QueuePtr; typedef struct{ QueuePtr front, rear; }LinkQueue;
有了队列这种结构后,就可以进行队列元素的插入操作了。
Status EnQueue ( LinkQueue *Q, QElemType e ){ QueuePtr s = ( QueuePtr ) malloc ( sizeof ( struct QNode ) ); if ( !s ) exit ( OVERFLOW ); s->data = e; s->next = NULL; Q->rear->next = s; Q->rear = s; return OK; }
同样的,元素的删除操作。
Status DeQueue ( LinkQueue *Q, QElemType *e ){ QueuePtr p; if ( Q->front == Q->rear ) return ERROR; p = Q->front->next; *e = p->data; Q->front->next = p->next; if ( Q->rear == p ) Q->rear = Q->front; free ( p ); return OK; }
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
标题名称:队列的链式存储结构-创新互联
文章来源:http://scyanting.com/article/sppio.html