c++中queue用法超詳細(xì)講解(入門必看!)
1、queue的作用
說(shuō)到queue,大家一定會(huì)想到stack,同樣是簡(jiǎn)單易用的數(shù)據(jù)結(jié)構(gòu)之一。queue就是隊(duì)列的意思,像大家日常排隊(duì)一樣,先排的人先用。stack則是相反的,后來(lái)的先用。這就有了queue先進(jìn)先出,stack后進(jìn)先出的說(shuō)法。
queue是一個(gè)很簡(jiǎn)單的數(shù)據(jù)結(jié)構(gòu),但是卻非常實(shí)用,同時(shí)也是必不可少的,其它的數(shù)據(jù)結(jié)構(gòu)都無(wú)法替代隊(duì)列。
queue常用于模仿隊(duì)列,在算法中比較常用的有單調(diào)隊(duì)列算法
相信看完本文就能上手使用了
2、queue的定義
queue<儲(chǔ)存的類型> 容器名
如:
儲(chǔ)存int型數(shù)據(jù)的隊(duì)列 queue q;
儲(chǔ)存double型數(shù)據(jù)的隊(duì)列 queue q;
儲(chǔ)存string型數(shù)據(jù)的隊(duì)列 queue q;
儲(chǔ)存結(jié)構(gòu)體或者類的隊(duì)列 queue<結(jié)構(gòu)體名> q;
3、queue的成員函數(shù)
back() //返回最后一個(gè)元素 empty() //如果隊(duì)列空則返回真 front() //返回第一個(gè)元素 pop() //刪除第一個(gè)元素 push() //在末尾加入一個(gè)元素 size() //返回隊(duì)列中元素的個(gè)數(shù)
示例代碼:
#include<iostream>//c++標(biāo)準(zhǔn)頭文件,可以使用cout,cin等標(biāo)準(zhǔn)庫(kù)函數(shù) #include<queue>//使用queue時(shí)需要的頭文件 using namespace std;//命名空間,防止重名給程序帶來(lái)各種隱患,使用cin,cout,stack,map,set,vector,queue時(shí)都要使用 int main(){ queue<int> q;//定義一個(gè)int類型的隊(duì)列 q.push(1);//在隊(duì)尾添加元素1 q.push(2);//在隊(duì)尾添加元素2 q.push(3);//在隊(duì)尾添加元素3 cout<<"插入元素1、2、3后,目前隊(duì)列中的元素:1 2 3"<<endl; cout<<"q.size()="<<q.size()<<endl;//q.size()查看目前隊(duì)列中的元素個(gè)數(shù) cout<<"q.empty()="<<q.empty()<<endl;//查看隊(duì)列是否為空,1即為空,0即非空 cout<<"q.front()="<<q.front()<<endl; //查看隊(duì)首元素 cout<<endl; q.pop();//隊(duì)首元素出隊(duì) cout<<"q.pop()后,目前隊(duì)列中的元素:2 3 "<<endl; cout<<"q.size()="<<q.size()<<endl;//q.size()查看目前隊(duì)列中的元素個(gè)數(shù) cout<<"q.empty()="<<q.empty()<<endl;//查看隊(duì)列是否為空,1即為空,0即非空 cout<<"q.front()="<<q.front()<<endl; //查看隊(duì)首元素 cout<<endl; q.pop();//隊(duì)首元素出隊(duì) cout<<"q.pop()后,目前隊(duì)列中的元素:3" <<endl; cout<<"q.size()="<<q.size()<<endl;//q.size()查看目前隊(duì)列中的元素個(gè)數(shù) cout<<"q.empty()="<<q.empty()<<endl;//查看隊(duì)列是否為空,1即為空,0即非空 cout<<"q.front()="<<q.front()<<endl; //查看隊(duì)首元素 cout<<endl; q.pop();//隊(duì)首元素出隊(duì) cout<<"q.pop()后,目前隊(duì)列是空的"<<endl; cout<<"q.size()="<<q.size()<<endl;//q.size()查看目前隊(duì)列中的元素個(gè)數(shù) cout<<"q.empty()="<<q.empty()<<endl;//查看隊(duì)列是否為空,1即為空,0即非空 cout<<"隊(duì)列是空的時(shí)候?qū)⒉荒苡胵.front()查看隊(duì)首元素" <<endl; }
運(yùn)行結(jié)果:
插入元素1、2、3后,目前隊(duì)列中的元素:1 2 3
q.size()=3
q.empty()=0
q.front()=1q.pop()后,目前隊(duì)列中的元素:2 3
q.size()=2
q.empty()=0
q.front()=2q.pop()后,目前隊(duì)列中的元素:3
q.size()=1
q.empty()=0
q.front()=3q.pop()后,目前隊(duì)列是空的
q.size()=0
q.empty()=1
隊(duì)列是空的時(shí)候?qū)⒉荒苡胵.front()查看隊(duì)首元素
queue和stack都是不能隨機(jī)訪問(wèn)的,即通過(guò)下標(biāo)訪問(wèn)元素,也不能遍歷
至此隊(duì)列的基本用法就學(xué)完咯
是不是很簡(jiǎn)單呢?
剛接觸肯定會(huì)覺(jué)得難,多些做題多些用,熟悉了就容易了,兄弟萌,加油?。?!
總結(jié)
到此這篇關(guān)于c++中queue用法的文章就介紹到這了,更多相關(guān)c++ queue用法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
c++讀取數(shù)據(jù)文件到數(shù)組的實(shí)例
今天小編就為大家分享一篇c++讀取數(shù)據(jù)文件到數(shù)組的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-07-07C++ 將數(shù)據(jù)轉(zhuǎn)為字符串的幾種方法
這篇文章主要介紹了C++ 將數(shù)據(jù)轉(zhuǎn)為字符串的幾種方法,十分的實(shí)用,有需要的小伙伴可以參考下。2015-06-06C++實(shí)現(xiàn)簡(jiǎn)易圖書館管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)簡(jiǎn)易圖書館管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03詳解C語(yǔ)言中telldir()函數(shù)和seekdir()函數(shù)的用法
這篇文章主要介紹了詳解C語(yǔ)言中telldir()函數(shù)和seekdir()函數(shù)的用法,是C語(yǔ)言入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-09-09解決了個(gè)困擾了2天的問(wèn)題,定點(diǎn)運(yùn)算問(wèn)題
本文主要講解定點(diǎn)運(yùn)算問(wèn)題,需要的朋友可以參考一下。2016-06-06C++用函數(shù)對(duì)算法性能進(jìn)行測(cè)試
算法無(wú)處不在,算法是程序的靈魂,而數(shù)據(jù)結(jié)構(gòu)則是程序的骨架,二者共同構(gòu)成了程序,那么如何評(píng)估算法的性能呢?理論上可以通過(guò)計(jì)算時(shí)間復(fù)雜度的方法來(lái)評(píng)估,但這是理性的認(rèn)識(shí),我們還有一種直觀的評(píng)估方法,那就是程序執(zhí)行的時(shí)間2022-08-08