1.對迭代器物件加上或減去乙個整型值iter+你,iter-n,將產生乙個新的迭代器,其位置在iter所指元素之前(加)或之後(減)n個元素的位置。加上或減去的值的型別應該是vector的size_type或difference_type型別。
2.iter1-iter2用來計算兩個迭代器物件的距離,該距離是名為difference_type的signed型別的值。difference_type是signed型別,該型別可以保證足夠大的以儲存任何兩個迭代器物件間的距離。iter1及iter2兩者必須都指向同一vector中的元素,或者指向vector末端之後的下乙個元素。
vector::iterator mid = vi.begin() + vi.size()/2; //初始化mid,使其指向vi中最靠近正中間的元素。
注:任何改變vector長度的操作都會使已存在的迭代器失效。如在呼叫push_back()之後,就不能再信賴指向vector的迭代器的值了。
有些程式要處理二進位制位的有序集,每個位可能包含0(關)值或1(開)值。位是用來儲存一組項或條件的yes/no資訊(標誌)的簡潔方法。
#include
using std::bitset;
bitset類是一種模板,與vector不同的是bitset型別物件的區別僅在其長度而不在其型別。在定義bitset時,要明確bitset含有多少位,須在尖括號內給出它的長度值。
bitset<32> bitvec;//給出的長度值必須是常量表示式。必須定義為整型字面值常量,或已用常量初始化的整型的const變數。
和vector中的元素一樣,bitset中的位是沒有命名的,只能按位置來訪問它們。
位集合的位置編號從0開始,以0位開始的位串是低階位,以31位結束的位串是高階位。
標準庫bitset型別
有些程式要處理二進位制位的有序集,每個位可能包含0或1.標準庫提供的bitset類簡化了位集的處理。要使用bitset類必須包含相關的標頭檔案類似於vector,bitset類是乙個模板,而不同的是bitset型別物件的區別在於長度而不是型別,定義bitset時,要在尖括號內給出它的長度值。bits...
標準庫型別bitset型別
標準庫bitset型別 bitset標頭檔案 include bitset的定義 bitset 位數 變數名 bitset的初始化方式 bitsetb b有n位,每位都為0 bitsetb u b是unsigned long u的乙個副本 bitsetb s b是string物件s中含有的位串的副本...
c 標準庫bitset型別
1.bitset物件的定義及初始化 eg bitset 32 a a的大小為32位二進位制 bitset 16 b 0xffff b的大小位16位,且初值為0xffff 括號中為賦值,可為任何進製,計算機會進行自動的轉化 string str 1011111000011111000000111000...