成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

C++迭代器怎么用-創(chuàng)新互聯(lián)

這篇文章主要介紹了C++迭代器怎么用,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

成都創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供清河網(wǎng)站建設(shè)、清河做網(wǎng)站、清河網(wǎng)站設(shè)計、清河網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、清河企業(yè)網(wǎng)站模板建站服務(wù),十載清河做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。

一、迭代器的特點

  • 迭代器是一種智能指針,具有遍歷復(fù)雜數(shù)據(jù)結(jié)構(gòu)的能力

  • 不同的容器有不一樣的內(nèi)部結(jié)構(gòu),因此會有一樣的迭代器類型

  • 迭代器定義后,并不屬于某一實例容器對象,只要是屬于該迭代器類型的容器類型都可用

迭代器的分類

C++的STL定義了5種迭代器

  • 輸入迭代器:提供了對其指向元素的只讀操作以及前++和后++操作符

  • 輸出迭代器:提供了對其指向元素的寫操作和++操作符

  • 向前迭代器:具有++操作符

  • 雙向迭代器:既具有++操作符也具有--操作符

  • 隨機(jī)訪問迭代器:是一般的迭代器,既可以隨機(jī)的實現(xiàn)跳躍跳動,也可以通過指針?biāo)阈g(shù)運算來實現(xiàn)跳躍移動

二、迭代器的使用

1.原理:迭代器定義之后,可指向指定類型容器內(nèi)的元素,從而達(dá)到訪問容器內(nèi)元素的能力

2.用法

  • 關(guān)鍵字interator代表聲明一個迭代器,前面需要指明類型

  • 迭代器指向容器的某一位置

  • 通過*解引用獲取元素的引用(注:*得到的是元素的引用)。也可用->得到該元素的成員(下面代碼會介紹)

string s= "HelloWorld";
string::iterator i; //一個string類型的迭代器
for (i = s.begin(); i != s.end(); i++)
{
  cout << *i;
}

3.解引用和成員訪問

注意:訪問成員時,要對迭代器加上(),否則產(chǎn)生的意義不同

(*item).empty(); //正確用法
*item.empty; //錯誤用法

上面代碼中:第一行是解引用迭代器。而第二種是試圖訪問item中的empty成員,但是item是個迭代器,顯示是錯誤的

三、interator、const_iterator 

1.迭代器的核心關(guān)鍵字

屬于容器的內(nèi)部成員,通過作用域限定符::訪問

2.分類

  • interator:當(dāng)我們需要對容器元素進(jìn)行修改、刪除等操作時或者對象是非常量時使用

  • const_iterator:當(dāng)我們只是遍歷容器元素,而不更改容器元素時或者對象是常量時使用

注意:上面所說的常量是指常量容器,而不是容器內(nèi)的元素為常量

3.兩者的選擇

建議:如果我們只是簡單的遍歷容器元素或者對象是常量時,一般使用const_iterator比較合適

4.C++11標(biāo)準(zhǔn):cbegin()、cend()

C++11引進(jìn)了兩個新函數(shù),分別為cbegin()、cend(),其兩者的功能類似于begin()、end()

C++11標(biāo)準(zhǔn)之前,iterator與const_iterator都使用begin()、end()兩個輔助函數(shù)遍歷容器。

C++11標(biāo)準(zhǔn)之后,const_iterator既可以使用可以使用begin()、end(),也可以使用cbegin()、cend()。但是iterator還是只能使用begin()、end()

vector<int> v;
const vector<int> v2;
auto it1=v.begin(); //v1是vector<int>::iterator類型
auto it2=v2.cbegin();//v2是vector<int>::const_iterator類型

四、reverse_interator、const_reverse_interator

1.概念

標(biāo)準(zhǔn)模板庫容器的逆序迭代器

功能與interator、const_iterator均相同,但是用法不一樣

2.兩者區(qū)別

  • reverse_interator:與interator相同,改變?nèi)萜鲀?nèi)部元素時使用。只能使用rbegin()、rend()

  • const_reverse_interator:與const_iterator相同,只是單純遍歷容器內(nèi)部元素時使用。能使用rbegin()、rend()、crbegin()、crend()

3.用法

用法的原理與interator、const_iterator是相同的

但是rbegin()、rend()分別指向容器元素的最后一個位置與第一個元素的前一個位置

//for循環(huán)打印的是3、2、1
 
vector<int> v;
vector<int>::const_reverse_iterator iter;
v.push_back(1);
v.push_back(2);
v.push_back(3);
for (iter = v.rbegin(); iter != v.rend(); iter++)
    printf("%d\t", *iter);

五、begin()、end()、cbegin()、cend()

4者都是容器的成員函數(shù)

cbegin()與cend()與begin()和end()原理相同,下面只介紹begin()與end()

1.概念:begin()、end()代表容器的特殊位置,分別為元素的第一個位置與最后一個元素的下一個位置

下面比如是vector的一個模型,則begin()、end()分別代表一下位置

C++迭代器怎么用

2.為什么要這樣設(shè)計?

  • begin():我們在遍歷容器的元素的時候,一般要獲取該元素的首元素,因此設(shè)計bengin()

  • end():當(dāng)我們用迭代器遍歷容器的時候,一般需要結(jié)束條件(如遍歷到最后一個元素),但是遍歷到最后一個元素時又不能舍棄它,因此將最后一個元素的下一位置作為結(jié)束標(biāo)志

六、rbegin()、rend()、crbegin()、crend()

這四者的原理與begin()、end()、cbegin()、cend()是相同的,也都是容器的成員函數(shù)

但是rbegin()、rend()分別代表最后一個元素與第一個元素的前一個位置

C++迭代器怎么用

七、迭代器的運算

說明:迭代器的運算符一般都是對迭代器所指元素的位置進(jìn)行比較,返回的是比較結(jié)果或者改變迭代器的位置

迭代器沒有+運算

例如有迭代器iter,iter1,iter2

*iter 返回迭代器所指元素的引用
iter->data 代表當(dāng)前所指位置處元素的的指針,可以訪問其函數(shù)或成員,等價于(*iter).data
++iter 令迭代器指向容器的下一個元素
--iter 令迭代器指向容器的前一個元素
iter1==iter2 判斷兩個迭代器的位置是否相同
iter1!=iter2 同上
>、>=、<、<= 同上

iter + n 改變迭代器的位置
iter - n 同上
iter +=n 同上
iter -=n 同上
iter1 - iter2 兩個迭代器相減,返回它們之間的距離

實例:遍歷vector中的元素,如果遇到空白,停止遍歷

vector<string> v = {"Hello","fwe",""};
vector<string>::iterator iter;
for (iter = v.begin(); iter != v.end() && !iter->empty(); ++iter)
{
  cout << *iter<<"\t";
}

八、一些代碼事例

將string中的第一個字符改為大寫

string s = "helloWorld";
string::iterator it;
if (s.begin() != s.end())//先判斷s不為空
{
  it = s.begin();
  *it = toupper(*it);
}

使用容器元素的函數(shù)

(*item).empty(); //判斷是否為空
(*item).size(); //得到大小

得到中間元素的迭代器

auto mid=v.begin()+vi.size()/2;

折半查找string中的一個元素

string s = "abcdefghj";
char foundChar = 'e';
string::const_iterator l_iter=s.begin();
string::const_iterator r_iter=s.end();
string::const_iterator mid_iter = s.begin() + (r_iter - l_iter) / 2;
while (mid_iter != r_iter && *mid_iter != foundChar)
{
  if (*mid_iter > foundChar)
  {
    r_iter = mid_iter;
  }
  else
  {
    l_iter = mid_iter + 1;
  }
  mid_iter = l_iter + (r_iter - l_iter) / 2;
}
cout << *mid_iter << endl;

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“C++迭代器怎么用”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián)建站,關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站jinyejixie.com,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

當(dāng)前標(biāo)題:C++迭代器怎么用-創(chuàng)新互聯(lián)
文章轉(zhuǎn)載:http://jinyejixie.com/article4/dedsoe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供ChatGPT、定制網(wǎng)站營銷型網(wǎng)站建設(shè)、軟件開發(fā)定制開發(fā)、關(guān)鍵詞優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁設(shè)計公司
阳新县| 乌鲁木齐县| 松潘县| 右玉县| 高碑店市| 吴川市| 丹江口市| 施甸县| 沈阳市| 临泽县| 当阳市| 壶关县| 民权县| 万荣县| 吉首市| 万山特区| 永城市| 文山县| 平山县| 蒲江县| 湘西| 营口市| 寿光市| 全椒县| 饶平县| 红原县| 尉氏县| 泰和县| 铜山县| 武清区| 山西省| 靖州| 兰州市| 三穗县| 津市市| 沭阳县| 乡宁县| 马尔康县| 金堂县| 河北省| 惠来县|