青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 12,  comments - 10,  trackbacks - 0
STL set 常用操作簡介
STL set 常用操作簡介

[size=4][color=Black]這是微軟幫助文檔中對集合(set)的解釋: “描述了一個控制變長元素序列的對象(注:set中的key和value是Key類型的,而map中的key和value是一個pair結構中的兩個分 量)的模板類,每一個元素包含了一個排序鍵(sort key)和一個值(value)。對這個序列可以進行查找、插入、刪除序列中的任意一個元素,而完成這些操作的時間同這個序列中元素個數的對數成比例關 系,并且當游標指向一個已刪除的元素時,刪除操作無效。”
而一個經過更正的和更加實際的定義應該是:一個集合(set)是一個容器,它其中所包含的元素的值是唯一的。這在收集一個數據的具體值的時候是有用的。集 合中的元素按一定的順序排列,并被作為集合中的實例。如果你需要一個鍵/值對(pair)來存儲數據,map是一個更好的選擇。一個集合通過一個鏈表來組 織,在插入操作和刪除操作上比向量(vector)快,但查找或添加末尾的元素時會有些慢。

下面是一個例子:

//程序:set演示
//目的:理解STL中的集合(set)

#include <string>
#include <set>
#include <iostream>
using namespace std;

int main(int argc, char* argv[])
{
set <string> strset;
set <string>::iterator si;
strset.insert("cantaloupes");
strset.insert("apple");
strset.insert("orange");
strset.insert("banana");
strset.insert("grapes");
strset.insert("grapes");
for (si=strset.begin(); si!=strset.end(); si++)
{ cout << *si << " "; }
cout << endl;
return 0;
}

// 輸出: apple banana cantaloupes grapes orange
//注意:輸出的集合中的元素是按字母大小順序排列的,而且每個值都不重復。

如果你感興趣的話,你可以將輸出循環用下面的代碼替換:

copy(strset.begin(), strset.end(), ostream_iterator<string>(cout, " "));

.集合(set)雖然更強大,但我個人認為它有些不清晰的地方而且更容易出錯,如果你明白了這一點,你會知道用集合(set)可以做什么。

所有的STL容器

容器(Container)的概念的出現早于模板(template),它原本是一個計算機科學領域中的一個重要概念,但在這里,它的概念和STL混合在一起了。下面是在STL中出現的7種容器:

vector(向量)——STL中標準而安全的數組。只能在vector 的“前面”增加數據。

deque(雙端隊列double-ended queue)——在功能上和vector相似,但是可以在前后兩端向其中添加數據。

list(列表)——游標一次只可以移動一步。如果你對鏈表已經很熟悉,那么STL中的list則是一個雙向鏈表(每個節點有指向前驅和指向后繼的兩個指針)。

set(集合)——包含了經過排序了的數據,這些數據的值(value)必須是唯一的。

map(映射)——經過排序了的二元組的集合,map中的每個元素都是由兩個值組成,其中的key(鍵值,一個map中的鍵值必須是唯一的)是在排序 或搜索時使用,它的值可以在容器中重新獲?。欢硪粋€值是該元素關聯的數值。比如,除了可以ar[43] = "overripe"這樣找到一個數據,map還可以通過ar["banana"] = "overripe"這樣的方法找到一個數據。如果你想獲得其中的元素信息,通過輸入元素的全名就可以輕松實現。

multiset(多重集)——和集合(set)相似,然而其中的值不要求必須是唯一的(即可以有重復)。

multimap(多重映射)——和映射(map)相似,然而其中的鍵值不要求必須是唯一的(即可以有重復)。
注意:如果你閱讀微軟的幫助文檔,你會遇到對每種容器的效率的陳述。比如:log(n*n)的插入時間。除非你要處理大量的數據,否則這些時間的影響是可 以忽略的。如果你發現你的程序有明顯的滯后感或者需要處理時間攸關(time critical)的事情,你可以去了解更多有關各種容器運行效率的話題。

怎樣在一個map中使用類?

Map是一個通過key(鍵)來獲得value(值)的模板類。

另一個問題是你希望在map中使用自己的類而不是已有的數據類型,比如現在已經用過的int。建立一個“為模板準備的(template-ready)”類,你必須確保在該類中包含一些成員函數和重載操作符。下面的一些成員是必須的:

缺省的構造函數(通常為空)

拷貝構造函數

重載的”=”運算符

你應該重載盡可能多的運算符來滿足特定模板的需要,比如,如果你想定義一個類作為 map中的鍵(key),你必須重載相關的運算符。但在這里不對重載運算符做過多討論了。

//程序:映射自定義的類。
//目的:說明在map中怎樣使用自定義的類。

#include <string>
#include <iostream>
#include <vector>
#include <map>
using namespace std;

class CStudent
{
public :
int nStudentID;
int nAge;
public :
//缺省構造函數——通常為空
CStudent() { }
// 完整的構造函數
CStudent(int nSID, int nA) { nStudentID=nSID; nAge=nA; }
//拷貝構造函數
CStudent(const CStudent& ob)
{
nStudentID=ob.nStudentID; nAge=ob.nAge; }
// 重載“=”
void operator = (const CStudent& ob)
{
nStudentID=ob.nStudentID; nAge=ob.nAge;
}
};

int main(int argc, char* argv[])
{
map <string, CStudent> mapStudent;

mapStudent["Joe Lennon"] = CStudent(103547, 22);
mapStudent["Phil McCartney"] = CStudent(100723, 22);
mapStudent["Raoul Starr"] = CStudent(107350, 24);
mapStudent["Gordon Hamilton"] = CStudent(102330, 22);

// 通過姓名來訪問Cstudent類中的成員
cout << "The Student number for Joe Lennon is " <<
(mapStudent["Joe Lennon"].nStudentID) << endl;

return 0;
}

TYPEDEF

如果你喜歡使用typedef關鍵字,下面是個例子:

typedef set <int> SET_INT;
typedef SET_INT::iterator SET_INT_ITER

編寫代碼的一個習慣就是使用大寫字母和下劃線來命名數據類型。

ANSI / ISO字符串

ANSI/ISO字符串在STL容器中使用得很普遍。這是標準的字符串類,并得到了廣泛地提倡,然而在缺乏格式聲明的情況下就會出問題。你必須使用“<<”和輸入輸出流(iostream)代碼(如dec, width等)將字符串串聯起來。

可在必要的時候使用c_str()來重新獲得字符指針。[/color][/size]
posted on 2009-04-17 17:40 zhoubaozhong 閱讀(493) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


<2009年4月>
2930311234
567891011
12131415161718
19202122232425
262728293012
3456789

常用鏈接

留言簿(3)

隨筆檔案

杭電!!

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久精品99国产精品日本| 久久综合色8888| 国产精品福利在线| 亚洲一区二区四区| 亚洲欧美日韩一区| 国内精品免费午夜毛片| 美女亚洲精品| 欧美精品激情在线| 亚洲一区二区三区四区五区黄 | 亚洲六月丁香色婷婷综合久久| 美日韩丰满少妇在线观看| 久久在线免费视频| av成人免费在线| 亚洲欧美日韩国产精品| 狠狠色综合网站久久久久久久| 欧美大片免费久久精品三p | 欧美二区视频| 亚洲一区图片| 久久久久久久精| 一本色道久久88精品综合| 亚洲一区国产视频| 亚洲国产精品va| 一本色道**综合亚洲精品蜜桃冫| 国产欧美另类| 亚洲精品三级| 国产一级精品aaaaa看| 亚洲国产精品久久久久| 国产精品高潮在线| 农夫在线精品视频免费观看| 国产精品成人aaaaa网站| 久久综合九色九九| 欧美日韩在线三区| 欧美不卡视频一区发布| 国产精品久久久久999| 你懂的网址国产 欧美| 国产精品私房写真福利视频| 亚洲国产成人高清精品| 国产欧美在线播放| 亚洲人成在线观看一区二区| 国内精品久久久久久影视8| 亚洲精品久久久久久一区二区| 激情综合在线| 亚洲一区二区三区色| 日韩午夜电影在线观看| 久久九九全国免费精品观看| 亚洲一区免费观看| 欧美大片免费| 你懂的国产精品| 国产日韩在线一区| 亚洲一区欧美激情| 亚洲视频专区在线| 欧美精品www| 亚洲第一色在线| 精品不卡一区二区三区| 新狼窝色av性久久久久久| 中国成人亚色综合网站| 欧美精品免费在线观看| 亚洲第一中文字幕| 亚洲国产小视频| 母乳一区在线观看| 欧美成人福利视频| 亚洲国产va精品久久久不卡综合| 欧美综合二区| 久久夜精品va视频免费观看| 国产伦精品一区二区三区四区免费 | 午夜欧美大尺度福利影院在线看| 欧美日韩hd| 夜夜精品视频| 亚洲欧美在线磁力| 国产欧美日韩视频一区二区三区| 中文精品一区二区三区| 亚洲一区二区三区四区五区午夜| 欧美日韩成人在线| 亚洲精品乱码久久久久久蜜桃91| 91久久精品国产91性色tv| 免费成人高清| 91久久精品国产91性色| 一区二区三区国产精品| 国产精品videosex极品| 亚洲天堂免费在线观看视频| 欧美一区二区三区四区在线| 国产婷婷色一区二区三区| 欧美中文日韩| 欧美成人免费在线观看| 亚洲精品色婷婷福利天堂| 欧美激情在线观看| 99精品欧美一区二区蜜桃免费| 正在播放日韩| 国产午夜精品全部视频在线播放| 欧美在线免费视频| 欧美国产免费| 亚洲一区二区在线| 国产在线不卡精品| 欧美jjzz| 欧美一级午夜免费电影| 欧美成人国产| 亚洲在线成人| 国产一区av在线| 欧美精品日韩| 欧美亚洲综合另类| 亚洲日本欧美在线| 性久久久久久久久久久久| 精品二区久久| 国产精品久久久久久久一区探花 | 99精品福利视频| 久久久999| 国产精品99久久久久久宅男| 国产精品一区二区三区久久久| 久久―日本道色综合久久| 日韩视频不卡| 欧美国产日韩二区| 欧美一站二站| 在线一区亚洲| 亚洲三级影院| 国产亚洲激情在线| 国产精品igao视频网网址不卡日韩 | 久久精品亚洲热| 日韩一区二区免费高清| 狠狠色狠狠色综合日日小说| 欧美日韩国产在线观看| 久久久999精品免费| 亚洲图片欧美一区| 亚洲黄色影片| 男人插女人欧美| 久久夜色精品国产欧美乱极品 | **网站欧美大片在线观看| 国产精品v欧美精品v日韩精品 | 午夜国产精品视频免费体验区| 亚洲国产精品一区二区久| 久久人人爽人人爽爽久久| 欧美一区二区三区免费在线看| 亚洲乱码国产乱码精品精98午夜| 亚洲电影第1页| 好看的日韩av电影| 国产丝袜美腿一区二区三区| 国产精品美女久久久久aⅴ国产馆| 欧美成人免费va影院高清| 久久久久久久久岛国免费| 欧美在线观看视频一区二区| 午夜伦欧美伦电影理论片| 亚洲自拍偷拍色片视频| 一区二区日韩免费看| 一本久久青青| 亚洲一区在线免费| 亚洲综合丁香| 欧美一区二区三区免费在线看| 性色av一区二区三区| 亚洲欧美日韩中文在线制服| 亚洲欧美中日韩| 亚洲一区二区三区四区视频| 亚洲一区精品电影| 亚洲欧美一区二区三区极速播放| 午夜久久久久久久久久一区二区| 午夜一区二区三区不卡视频| 欧美一区二区三区在线视频| 久久精品动漫| 欧美aa国产视频| 欧美日韩国产精品一区二区亚洲| 欧美日韩伦理在线免费| 国产精品久久久久久久久久免费看 | 99亚洲一区二区| 亚洲一区二区综合| 欧美在线1区| 欧美成人午夜视频| 国产精品a久久久久| 国产亚洲欧洲| 亚洲高清在线| 亚洲一区二区三区涩| 欧美制服丝袜第一页| 欧美jizz19hd性欧美| 亚洲区国产区| 午夜精品久久久久久久| 久久青青草原一区二区| 欧美日韩国产黄| 国产伪娘ts一区| 亚洲精品一区二区三区在线观看 | 亚洲一区二区影院| 香蕉av福利精品导航| 蜜桃伊人久久| 一区二区三区国产在线| 久久精品一区二区国产| 欧美久久久久久久| 国内精品久久久久久影视8| 亚洲靠逼com| 销魂美女一区二区三区视频在线| 女人天堂亚洲aⅴ在线观看| 在线综合亚洲| 欧美成人一区二免费视频软件| 国产精品s色| 亚洲激情啪啪| 久久精品成人一区二区三区蜜臀 | 欧美在线日韩| 亚洲精品社区| 久久久久国产精品麻豆ai换脸| 欧美日韩免费高清| 午夜在线观看欧美| 欧美不卡视频一区| 性色av一区二区三区红粉影视| 欧美另类一区二区三区| 亚洲第一页在线|