網站首頁 編程語言 正文
說明
循環隊列是一種先進先出的,首尾相連的隊列。
大致的結構如下圖:
用數組來抽象的表示一下的話,如下圖:
循環隊列有兩個指針指向數據,上圖中的start和end就是那兩個指針,它們指向相同的位置,表示的是空,即隊列是空的。
隨著數據的放入,隊列一般有下面的兩種形式:
需要注意第二種形式,從圖上看end在start的前面了,但是因為循環關系,前后并不重要。
另外需要考慮的是隊列滿的情況:
但這種情況存在一個問題,即空隊列和滿隊列沒有辦法區分了,end和start都指向了相同的位置。
為了解決這個問題,一個方法是空出一個位置不放數據,當end再加一個數據就等于start的時候就認為隊列是滿的:
這時實際的數據長度就會比分配的少1。
下面是隊列中空和滿的判斷:
1. 隊列為空時:end == start
2. 隊列為滿時:(end + 1) % size == start
這里的size是指分配的空間大小,而不是隊列長度,隊列的實際長度為(end - start + size) % size,最大長度是size-1
這也是因為要考慮循環的關系,所以要加上%size這個操作。
示例代碼
1. 首先定義結構體:
//定義循環隊列
typedef struct _LoopQueue {
int data[8]; //存放數據
int start; //頭指針
int end; //尾指針
} LoopQueue;
2. 定義各種算法:
#define TRUE 1
#define FALSE 0
#define SIZE 8
//初始化隊列
int init(LoopQueue *lq) {
lq->start = 0;
lq->end = 0;
return TRUE;
}
//判斷隊列是否為空
int isEmpty(LoopQueue *lq) {
if (lq->start == lq->end) {
return TRUE;
}
return FALSE;
}
//判斷隊列是否為滿
int isFull(LoopQueue *lq) {
if ((lq->end + 1) % SIZE == lq->start) {
return TRUE;
}
return FALSE;
}
//獲取隊列的長度
int getLength(LoopQueue *lq) {
return (lq->end - lq->start + SIZE) % SIZE;
}
//插入數據
int pushQueue(LoopQueue *lq, int data) {
if(isFull(lq)) {
printf("Queue is full.\n");
return FALSE;
}
lq->data[lq->end] = data;
lq->end = (lq->end + 1) % SIZE;
return TRUE;
}
//彈出數據
int popQueue(LoopQueue *lq, int *data) {
if (isEmpty(lq)) {
printf("Queue is empty.\n");
return FALSE;
}
*data = lq->data[lq->start];
lq->start = (lq->start + 1) % SIZE;
return TRUE;
}
//顯示隊列中的數據
void printQueue(LoopQueue *lq) {
int index;
int count;
count = getLength(lq);
if (0 == count) {
printf("No data.\n");
return;
}
for (index = 0; index < count; index++) {
printf("%d ", lq->data[index]);
}
printf("\n");
return;
}
3. 測試:
int main()
{
int index;
int num;
//隊列測試代碼
LoopQueue *lq = (LoopQueue *)malloc(sizeof(LoopQueue));
init(lq);
printQueue(lq);
for (index = 0; index < SIZE; index ++) { //注意這里要放8個數據,但是實際上只能放7個,所以最后一個會報錯
pushQueue(lq, index);
}
printQueue(lq);
for (index = 0; index < SIZE; index ++) { //同上,會打印一個錯誤
if (popQueue(lq, &num)) {
printf("%d\n", num);
}
}
printQueue(lq);
return 0;
}
4. 最后的結果:
原文鏈接:https://blog.csdn.net/jiangwei0512/article/details/50615086
相關推薦
- 2022-08-15 數據結構之數組棧的實現
- 2022-11-02 Go?語言簡單實現Vigenere加密算法_Golang
- 2022-06-11 嵌入式C語言二級指針在鏈表中的應用_C 語言
- 2021-11-27 關于UDP服務器客戶端編程流程介紹_C 語言
- 2023-02-15 清理或刪除docker無用鏡像的操作方法_docker
- 2022-05-25 Jenkins 簡單的從git上構建一個maven項目
- 2023-07-14 react 如何實現富文本編輯器
- 2023-03-18 k8s?service?nodePort無法訪問的問題解決_云其它
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支