亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C語言實(shí)現(xiàn)循環(huán)隊(duì)列基本操作

 更新時(shí)間:2021年09月24日 08:30:43   作者:似曾不相識  
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)循環(huán)隊(duì)列基本操作,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

循環(huán)隊(duì)列依靠取模運(yùn)算,實(shí)現(xiàn)隊(duì)列中數(shù)據(jù)元素的邏輯成環(huán)操作。其相比隊(duì)列的順序存儲(chǔ)實(shí)現(xiàn),可以避免“假溢出”的問題。

頭文件聲明

#include <stdio.h>
#include <stdlib.h>

/*
* 循環(huán)隊(duì)列實(shí)現(xiàn)
*/
//數(shù)據(jù)元素上限
#define MaxSize 50
//定義數(shù)據(jù)類型
typedef int ElemType;
/*結(jié)構(gòu)體定義*/
typedef struct SqQueue
{
 ElemType data[MaxSize];//數(shù)組-存放數(shù)據(jù)元素
 int front, //隊(duì)頭指針
  rear; //隊(duì)尾指針
}SqQueue;

//初始化隊(duì)列
void InitQueue(SqQueue *q);
//判斷隊(duì)列是否為空
int EmptyQueue(SqQueue q);
//入隊(duì)操作
int EnQueue(SqQueue *q,ElemType e);
//出隊(duì)操作
int DeQueue(SqQueue *q,ElemType* e);
//獲取隊(duì)列長度
int LengthQueue(SqQueue q);
//獲取隊(duì)頭元素
void GetHead(SqQueue q,ElemType* e);
//打印隊(duì)列
void printSqQueue(SqQueue q);

函數(shù)實(shí)現(xiàn)

#include "SqQueue.h"

/**
 * 循環(huán)隊(duì)列函數(shù)實(shí)現(xiàn)
 */

//初始化隊(duì)列
void InitQueue(SqQueue *q){
 //隊(duì)頭指針-隊(duì)尾指針,同時(shí)指向隊(duì)首元素
 q->front=q->rear=0;
}

//判斷隊(duì)列是否為空
int EmptyQueue(SqQueue q){
 //隊(duì)頭指針和隊(duì)尾指針指向同一個(gè)元素,則為空隊(duì)列
 return q.front==q.rear;
}

//入隊(duì)操作
int EnQueue(SqQueue *q,ElemType e){
 //判斷是否隊(duì)滿
 if ((q->rear+1)%MaxSize==q->rear)
  return -1;
 //入隊(duì)操作
 q->data[q->rear]=e;//添加數(shù)據(jù)元素-將隊(duì)尾元素值置為e
 q->rear=(q->rear+1)%MaxSize;//尾指針向前移動(dòng),隊(duì)尾指針++
 return 1;
}
//出隊(duì)操作
int DeQueue(SqQueue *q,ElemType* e){
 //判斷是否隊(duì)空
 if ((q->rear+1)%MaxSize==q->front)
  return -1;
 //保存數(shù)據(jù)
 *e=q->data[q->front];
 //出隊(duì)操作
 q->front=(q->front+1)%MaxSize;
 return 1;
}
//獲取隊(duì)列長度
int LengthQueue(SqQueue q){
 return (q.rear-q.front+MaxSize)%MaxSize;
}

//獲取隊(duì)頭元素
void GetHead(SqQueue q,ElemType* e){
 //判斷隊(duì)列是否為空
 if (q.front==q.rear)
  return;
 //獲取隊(duì)頭元素的值
 *e=q.data[q.front];
}

//打印隊(duì)列
void printSqQueue(SqQueue q){
 //輔助指針
 int pIndex;
 //打印隊(duì)列元素
 pIndex=q.front;
 while (pIndex<q.rear)
 {
  printf("%4d",q.data[pIndex++]);
 }
 printf("\n");
}

函數(shù)測試

#include "SqQueue.h"

int main(int argc,char** argv){
 //聲明隊(duì)列
 SqQueue sQueue;
 int i;
 ElemType data;
 //初始化隊(duì)列
 InitQueue(&sQueue);
 //獲取隊(duì)頭指針和隊(duì)尾指針的值
 printf("frontVal=%d,rearVal=%d\n",sQueue.front,sQueue.rear);
 //判斷隊(duì)列是否為空
 printf("is Empty?%d\n",EmptyQueue(sQueue));
 //入隊(duì)操作
 for (i=0;i<20;i++)
 {
  EnQueue(&sQueue,i+1);
 }
 //判斷隊(duì)列是否為空&獲取隊(duì)列長度
 printf("is Empty?%d,len=%d\n",EmptyQueue(sQueue),LengthQueue(sQueue));
 //打印隊(duì)列元素
 printSqQueue(sQueue);
 //出隊(duì)操作
 DeQueue(&sQueue,&data);
 printf("the aimed value is %d\n",data);
 //判斷隊(duì)列是否為空&獲取隊(duì)列長度
 printf("is Empty?%d,len=%d\n",EmptyQueue(sQueue),LengthQueue(sQueue));
 //打印隊(duì)列元素
 printSqQueue(sQueue);
 //獲取隊(duì)頭元素值
 GetHead(sQueue,&data);
 printf("the head value is %d\n",data);
 return 0;
}

再貼個(gè)測試結(jié)果的圖:

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C++基于hook iat改變Messagebox實(shí)例

    C++基于hook iat改變Messagebox實(shí)例

    這篇文章主要介紹了C++基于hook iat改變Messagebox的方法,以實(shí)例形式展示了針對IAT(即導(dǎo)入地址表)以及hook的操作,有助于深入理解Windows程序設(shè)計(jì)原理,需要的朋友可以參考下
    2014-10-10
  • C++?Qt實(shí)現(xiàn)一個(gè)解除文件占用小工具

    C++?Qt實(shí)現(xiàn)一個(gè)解除文件占用小工具

    這篇文章主要為大家詳細(xì)介紹了如何利用C++?Qt實(shí)現(xiàn)一個(gè)解除文件占用小工具,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-09-09
  • C語言猜兇手及類似題目的實(shí)現(xiàn)示例

    C語言猜兇手及類似題目的實(shí)現(xiàn)示例

    本文主要介紹了C語言猜兇手及類似題目的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • C語言實(shí)現(xiàn)控制臺五子棋小游戲

    C語言實(shí)現(xiàn)控制臺五子棋小游戲

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)控制臺五子棋小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • OpenCV實(shí)現(xiàn)圖像背景虛化效果原理詳解

    OpenCV實(shí)現(xiàn)圖像背景虛化效果原理詳解

    相信用過相機(jī)的同學(xué)都知道虛化特效,這是一種使焦點(diǎn)聚集在拍攝主題上,讓背景變得朦朧的效果。本文將詳細(xì)介紹一些這一效果的實(shí)現(xiàn)原理以及代碼,需要的可以參考一下
    2022-03-03
  • 基于Windows C++ 應(yīng)用程序通用日志組件的使用詳解

    基于Windows C++ 應(yīng)用程序通用日志組件的使用詳解

    眾所周知,在調(diào)試、跟蹤和執(zhí)行應(yīng)用程序的過程中,程序的日志能為這些工作提供大量有價(jià)值的運(yùn)行信息。因此,程序的日志對應(yīng)用程序的運(yùn)行、維護(hù)至關(guān)重要
    2013-05-05
  • 淺談返回函數(shù)內(nèi)部new分配的內(nèi)存的引用

    淺談返回函數(shù)內(nèi)部new分配的內(nèi)存的引用

    下面小編就為大家?guī)硪黄獪\談返回函數(shù)內(nèi)部new分配的內(nèi)存的引用。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-12-12
  • 詳解Qt使用QImage類實(shí)現(xiàn)圖像基本操作

    詳解Qt使用QImage類實(shí)現(xiàn)圖像基本操作

    這篇文章主要介紹了Qt如何利用QImage類實(shí)現(xiàn)對圖像的基本操作,包括圖像顯示、圖像縮放、圖像旋轉(zhuǎn)等,感興趣的小伙伴可以跟隨小編一起動(dòng)手嘗試一下
    2022-06-06
  • C++?opencv圖像處理使用cvtColor實(shí)現(xiàn)顏色轉(zhuǎn)換

    C++?opencv圖像處理使用cvtColor實(shí)現(xiàn)顏色轉(zhuǎn)換

    這篇文章主要為大家介紹了C++?opencv圖像處理cvtColor實(shí)現(xiàn)顏色轉(zhuǎn)換的實(shí)現(xiàn)示例代碼,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • 淺析順序結(jié)構(gòu)存儲(chǔ)的棧

    淺析順序結(jié)構(gòu)存儲(chǔ)的棧

    這篇文章主要介紹了順序結(jié)構(gòu)存儲(chǔ)的棧,有需要的朋友可以參考一下
    2014-01-01

最新評論