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

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

數據結構隊列

2019-11-08 20:04:46
字體:
來源:轉載
供稿:網友

隊列特性:先進先出(FIFO)——先進隊列的元素先出隊列。來源于我們生活中的隊列(先排隊的先辦完事)。

隊列有下面幾個操作:

InitQueue()   ——初始化隊列EnQueue()        ——進隊列DeQueue()        ——出隊列IsQueueEmpty()——判斷隊列是否為空IsQueueFull()    ——判斷隊列是否已滿

隊列可以由數組和鏈表兩種形式實現隊列操作(c語言),下面僅以數組為例:

數組實現:

隊列數據結構

復制代碼
typedef struct queue{        int queuesize;   //數組的大小        int head, tail;  //隊列的頭和尾下標        int *q;          //數組頭指針}Queue;復制代碼

InitQueue()   ——初始化隊列

復制代碼
void InitQueue(Queue *Q){        Q->queuesize = 8;        Q->q = (int *)malloc(sizeof(int) * Q->queuesize); //分配內存        Q->tail = 0;        Q->head = 0;}復制代碼

這樣有個缺陷,空間利用率不高。采用循環隊列:

 

EnQueue()        ——進隊列

復制代碼
void EnQueue(Queue *Q, int key){        int tail = (Q->tail+1) % Q->queuesize; //取余保證,當quil=queuesize-1時,再轉回0        if (tail == Q->head)                   //此時隊列沒有空間        {            PRintf("the queue has been filled full!");        }        else        {            Q->q[Q->tail] = key;            Q->tail = tail;        }}復制代碼

DeQueue()        ——出隊列

復制代碼
int DeQueue(Queue *Q){        int tmp;        if(Q->tail == Q->head)     //判斷隊列不為空        {            printf("the queue is NULL/n");        }        else        {            tmp = Q->q[q->head];            Q->head = (Q->head+1) % Q->queuesize;        }        return tmp;}復制代碼

IsQueueEmpty()——判斷隊列是否為空

復制代碼
int IsQueueEmpty(Queue *Q){        if(Q->head == Q->tail)        {            return 1;        }        else        {            return 0;        }}復制代碼

IsQueueFull()——判斷隊列是否已滿

復制代碼
int IsQueueFull(Queue *Q){    if((Q->tail+1)% Q->queuesize == Q->head)    {        return 1;    }    else    {        return 0;    }}復制代碼

 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 绥阳县| 元阳县| 乃东县| 梧州市| 常州市| 五常市| 高陵县| 房产| 梅州市| 大姚县| 石阡县| 博白县| 长治市| 屏东县| 灵石县| 景泰县| 巴彦县| 丹凤县| 淮阳县| 五家渠市| 靖边县| 合江县| 启东市| 云浮市| 玉田县| 当涂县| 东山县| 石城县| 肇庆市| 万宁市| 红河县| 吉首市| 年辖:市辖区| 龙泉市| 承德市| 小金县| 思茅市| 普兰店市| 卫辉市| 河间市| 大丰市|