首页 > 代码库 > 数据结构之第三章之队列
数据结构之第三章之队列
1~~队列的特点:队列是限定仅在表尾进行插入和表头进行删除操作的线性表,是先进先出的线性表。
1~~循环队列
(1)循环队列的循环表示
typedef struct { int *base;//初始化的动态分配存储空间 int front;//头指针,若队列不为空,指向队列头元素 int rear;//尾指针,若队列不空,指向队列尾元素的下一个位置}QUEUE;
若队列不空,尾指针始终指向队列尾元素的下一个位置,也即尾指针始终是"空闲的“,可以起到分隔作用。
2~~~入队
int enqueue(QUEUE head,int e){
//插入元素e为head的新的队尾元素
if((head.rear+1)%MAXQSIZE==head.front)
return 0;//队列满
head.base[head.rear]=e;
head.rear=(head+1)%MAXQSIZE;
return 1;
}
3~~~出队
int deletequeue(QUEUE head,int e){ //若队列不空,则删除队列head的队头元素,则用e返回 if(head.front==head.rear) return 0; e=head.base[head.front]; head.front=(head.front+1)%MAXQSIZE; return 1;}
4~~~判队空
bool queueempty(QUEUE head){//若队列不空,返回false,否则,返回trueif(head.rear==(head.front+1)%MAXQSIZE) return true;else return false;}
5~~~判队满
bool isfullqueue(QUEUE head){ //若队列为满,则返回true,否则返回false; if(head.front==((head.rear+1)%MAXQSIZE)) return true; else return false; }
2链式队列
(1)链式队列的存储表示
typedef struct Qnode{ int data; struct Qnode *next;}NODE,*QNODE;typedef struct{ QNODE front;//对头指针 QNODE rear;//队尾指针}LINKQUEUE;
链队列包含头指针和尾指针和头节点,当头指针和尾指针相等时,判定链队列为空;
删除队列头元素时,一般情况下,仅需修改头节点的指针,但当队列中只有最后一个元素被删除后,队列尾指针也将丢失,因此需对队列尾指针重新赋值,而元素入队时,只需修改尾指针。
(2) 入队(Enqueue)
int Enqueue(LINKQUEUE Q,int e){ //插入元素为e为Q的新的队尾元素 newbase=(QNODE)malloc(sizeof(NODE)); if(!newbase) exit(-1); newbase->data=http://www.mamicode.com/e; newbase->next=NULL; Q.rear->next=newbase; Q.rear=newbase; return 1; }
(3)出队
int deletequeue(LINKQUEUE Q,int e){ //若队列不空,则删除Q的队头元素,用e返回其值 if(Q.front==Q.rear) return 0; newbase=Q.front->next; e=newbase->data; Q.front->next=newbase->next; if(Q.rear==newbase) Q.rear=Q.front; free(newbase); return 1; }
(4)判队列
bool queueempty(LINKQUEUE Q){ //若队列空,返回true,否则返回false if(Q.front==Q.rear) return true; else return false; }
数据结构之第三章之队列
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。