C語言結(jié)構(gòu)及隊列實現(xiàn)示例詳解
1.隊列的概念及結(jié)構(gòu)
隊列:
只允許一端插入數(shù)據(jù),另一端刪除數(shù)據(jù)的特殊線性表
先進先出FIFO(First In First Out)
入隊列:
進行插入操作的一端稱為隊尾
出隊列:
進行刪除操作的一端稱為隊頭

2. 隊列的實現(xiàn)
隊列也可以數(shù)組和鏈表的結(jié)構(gòu)實現(xiàn),使用鏈表的結(jié)構(gòu)實現(xiàn)更優(yōu)一些,因為如果使用數(shù)組的結(jié)構(gòu),出隊列在數(shù)組頭上出數(shù)據(jù),效率會比較低。

DFS---深度優(yōu)先遍歷 -- 遞歸/棧實現(xiàn)非遞歸
BFS---廣度優(yōu)先遍歷 -- 隊列
// 鏈?zhǔn)浇Y(jié)構(gòu):表示隊列
#pragma once
#include <stdlib.h>
#include <assert.h>
#include <stdbool.h>
#include <stdio.h>
typedef int QDatatype;
typedef struct QueueNode
{
QDatatype data;
struct QueueNode* next;
}QNode;
typedef struct Queue
{
QNode* phead;
QNode* ptail;
int size;
}Queue;
//初始化隊列
void QueueInit(Queue* pq);
//隊尾入隊列
void QueuePush(Queue* pq , QDatatype x);
//隊頭出隊列
void QueuePop(Queue* pq);
//獲取隊頭元素
QDatatype QueueFront(Queue* pq);
//獲取隊尾元素
QDatatype QueueBack(Queue* pq);
//隊列大小
int QueueSize(Queue* pq);
//判斷隊列是否為空
bool QueueEmpty(Queue* pq);
//銷毀隊列
void QueueDestory(Queue* pq);#define _CRT_SECURE_NO_WARNINGS 1
#include "Queue.h"
//初始化隊列
void QueueInit(Queue* pq)
{
assert(pq);
pq->phead = NULL;
pq->ptail = NULL;
pq->size = 0;
}
//銷毀隊列
void QueueDestory(Queue* pq)
{
QNode* cur = pq->phead ;
while (cur)
{
/*QNode* tmp = cur;
cur = cur->next;
free(tmp);*/
QNode* next = cur->next;
free(cur);
cur = next;
}
pq->phead = pq->ptail = NULL;
pq->size = 0;
}
//隊尾入隊列
void QueuePush(Queue* pq, QDatatype x)
{
assert(pq);
QNode* newnode = (QNode*)malloc(sizeof(QNode));
if (newnode == NULL)
{
perror("malloc");
return;
}
newnode->data = x;
newnode->next = NULL;
if (pq->phead == NULL)//isEmpty
{
assert(pq->ptail==NULL);
pq->phead = newnode;
pq->ptail = newnode;
}
else
{
pq->ptail->next = newnode;
pq->ptail = newnode;
}
pq->size++;
}
//判斷隊列是否為空
bool QueueEmpty(Queue* pq)
{
assert(pq);
return pq->size == 0;
//return pq->phead == NULL && pq->ptail == NULL;
}
//隊頭出隊列
void QueuePop(Queue* pq)
{
assert(pq);
assert(!QueueEmpty(pq));//assert(pq->phead != NULL);
//1、一個節(jié)點
//2、多個節(jié)點
if (pq->phead->next == NULL)//一個節(jié)點要注意ptail別弄成野指針
{
free(pq->phead);
pq->phead = pq->ptail = NULL;
}
else
{
Queue* next = pq->phead->next;
free(pq->phead);
pq->phead = next;
}
pq->size--;
}
//獲取隊頭元素
QDatatype QueueFront(Queue* pq)
{
assert(pq);
assert(!QueueEmpty(pq));
return pq->phead->data;
}
//獲取隊尾元素
QDatatype QueueBack(Queue* pq)
{
assert(pq);
assert(!QueueEmpty(pq));
return pq->ptail->data;
}
//隊列大小
int QueueSize(Queue* pq)
{
assert(pq);
return pq->size;
}//測試
#define _CRT_SECURE_NO_WARNINGS 1
#include "Queue.h"
void TestQueue()
{
Queue q;
QueueInit(&q);
QueuePush(&q, 1);
QueuePush(&q, 2);
QueuePush(&q, 3);
QueuePush(&q, 4);
//QueuePop(&q);
//QueuePop(&q);
//QueuePop(&q);
//while (!QueueEmpty(&q))
//{
// printf("%d ", QueueFront(&q));
//
// QueuePop(&q);
//}
printf("\n");
//printf("%d ", QueueFront(&q));
//printf("%d ", QueueSize(&q));
//QueuePop(&q);
printf("%d ", QueueBack(&q));
printf("%d ", QueueBack(&q));
printf("%d ", QueueBack(&q));
QueueDestory(&q);
}
int main()
{
TestQueue();
return 0;
}以上就是C語言結(jié)構(gòu)及隊列實現(xiàn)示例詳解的詳細(xì)內(nèi)容,更多關(guān)于C語言結(jié)構(gòu)隊列的資料請關(guān)注腳本之家其它相關(guān)文章!
- C語言數(shù)據(jù)結(jié)構(gòu)與算法之隊列的實現(xiàn)詳解
- c語言數(shù)據(jù)結(jié)構(gòu)之棧和隊列詳解(Stack&Queue)
- C語言數(shù)據(jù)結(jié)構(gòu)之棧和隊列的實現(xiàn)及應(yīng)用
- C語言數(shù)據(jù)結(jié)構(gòu)之棧與隊列的相互實現(xiàn)
- C語言數(shù)據(jù)結(jié)構(gòu)之隊列的定義與實現(xiàn)
- C語言數(shù)據(jù)結(jié)構(gòu)算法基礎(chǔ)之循環(huán)隊列示例
- C語言數(shù)據(jù)結(jié)構(gòu)系列隊列篇
相關(guān)文章
C++20 統(tǒng)一容器擦除:std::erase 和 std::eraseif的實現(xiàn)
本文主要介紹了C++20 統(tǒng)一容器擦除:std::erase 和 std::erase_if的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2025-04-04
C++?指針和對象成員訪問的區(qū)別:`.`?與?`->`?的使用小結(jié)
在學(xué)習(xí)?C++?時,常常會遇到訪問對象成員的兩種符號:.?和?->,這兩個符號看似簡單,但它們的正確使用卻需要理解指針和對象的本質(zhì)差異,本文介紹C++?指針和對象成員訪問的區(qū)別:`.`?與?`->`?的使用指南,感興趣的朋友一起看看吧2024-12-12
淺析C語言中strtol()函數(shù)與strtoul()函數(shù)的用法
這篇文章主要介紹了淺析C語言中strtol()函數(shù)與strtoul()函數(shù)的用法,注意其將字符串轉(zhuǎn)換成long型的區(qū)別,需要的朋友可以參考下2015-08-08

