队列的链式存储结构-创新互联
由于线性存储结构有顺序存储和链式存储两种,而队列是一种特殊的线性结构,所以,队列自然也会有链式存储结构,这种存储结构,称之为“链队列”。只不过,这种结构需要两个指针,一个指针指向队列的头部,一个指针指向队列的尾部。虽然队列采用了链式存储这种方式,但是它本质上仍然是队列,因此,只要是队列,就要遵循:只允许在队列的头部进行删除操作,只允许在队里的尾部进行插入操作。那么,先来定义个链队列结构:

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://www.jxjierui.cn/article/sppio.html


咨询
建站咨询
