国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

隊列之順序隊基本操作

2019-11-11 05:46:27
字體:
來源:轉載
供稿:網友
/*  隊列是一種操作受限的線性表,其限制為僅允許在表的一端插入,在表的另一端進行刪除。  進行刪除的一端稱為隊頭或隊首,插入元素稱為入隊,刪除元素稱為出隊。  在順序隊*q中,隊空條件為q->front==q->rear。隊滿條件為q->rear==MaxSize-1.  入隊操作為先將隊尾指針增加1,然后把e放在隊尾。  出隊操作是先將隊頭指針增加1,然后取出隊頭元素。*/#include <stdio.h>#include <stdlib.h>#define MaxSize 5typedef char ElemType;typedef struct{    ElemType data[MaxSize];//存放隊列中的元素    int front,rear;//隊頭和隊尾指針}SQQueue;//定義順序隊的類型void InitQueue(SqQueue *&q)//初始化順序隊{    q = (SqQueue *)malloc(sizeof(SqQueue));    q->front= q->rear= -1;}void DestroyQueue(SqQueue *&q)//銷毀順序隊{    free(q);}bool QueueEmpty(SqQueue *q)//判斷順序隊是否為空{    return (q->front==q->rear);}bool enQueue(SqQueue *&q,ElemType e)//入隊{    if(q->rear==MaxSize-1)        return false;    q->rear++;    q->data[q->rear]=e;    return true;}bool deQueue(SqQueue *&q,ElemType &e)//出隊{    if(q->rear==q->front)        return false;    q->front++;    e = q->data[q->front];    return true ;}int main(){	ElemType e;	SqQueue *q;	PRintf("環形隊列基本運算如下:/n");	printf("  (1)初始化隊列q/n");	InitQueue(q);	printf("  (2)依次進隊列元素a,b,c/n");	if (!enQueue(q,'a')) printf("/t提示:隊滿,不能進隊/n");	if (!enQueue(q,'b')) printf("/t提示:隊滿,不能進隊/n");	if (!enQueue(q,'c')) printf("/t提示:隊滿,不能進隊/n");	printf("  (3)隊列為%s/n",(QueueEmpty(q)?"空":"非空"));	if (deQueue(q,e)==0)		printf("隊空,不能出隊/n");	else		printf("  (4)出隊一個元素%c/n",e);	printf("  (5)依次進隊列元素d,e,f/n");	if (!enQueue(q,'d')) printf("/t提示:隊滿,不能進隊/n");	if (!enQueue(q,'e')) printf("/t提示:隊滿,不能進隊/n");	if (!enQueue(q,'f')) printf("/t提示:隊滿,不能進隊/n");	printf("  (6)出隊列序列:");	while (!QueueEmpty(q))	{	deQueue(q,e);		printf("%c ",e);	}	printf("/n");	printf("  (7)釋放隊列/n");	DestroyQueue(q);    return 0;}

運行結果:


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 光山县| 轮台县| 江永县| 固镇县| 平湖市| 浠水县| 上高县| 睢宁县| 正宁县| 新密市| 特克斯县| 翁牛特旗| 贵溪市| 民丰县| 乐陵市| 修文县| 霍城县| 旺苍县| 从化市| 大竹县| 常德市| 汕尾市| 翁源县| 铁岭市| 神农架林区| 宁安市| 邵阳市| 申扎县| 海宁市| 上虞市| 方城县| 成武县| 江津市| 宜黄县| 西青区| 犍为县| 汉中市| 兴城市| 泉州市| 安仁县| 定陶县|