1.string
string的定義,初始化乡括,遍歷等基礎(chǔ)在此略去昭抒。
常用的string類型的操作
substr()
replace()
find()
split()
trim()
1.1 substr()
s.substr(pos,n)該函數(shù)截取s字符串從pos開(kāi)始計(jì)算共n個(gè),然后返回該子串府树。該函數(shù)由string類庫(kù)提供
1.2 replace()
s.replace(pos,len,args)該函數(shù)刪除s中從下表pos開(kāi)始的len個(gè)字符喜最,用args指定的字符替換偎蘸。
然后返回s的引用庄蹋。該函數(shù)也由string類庫(kù)提供
1.3 find()
s.find(args瞬内,pos)該函數(shù)從s的pos位置開(kāi)始查找args第一次出現(xiàn)的位置并返回該值。
該函數(shù)也由string類庫(kù)提供限书。
1.4 split()該函數(shù)由自己實(shí)現(xiàn)
<code>
void split(std::string& s, std::string& delim,std::vector< std::string >* ret)
{
size_t last = 0;
size_t index=s.find_first_of(delim,last);
while (index!=std::string::npos)
{
ret->push_back(s.substr(last,index-last));
last=index+1;
index=s.find_first_of(delim,last);
}
if (index-last>0)
{
ret->push_back(s.substr(last,index-last));
}
}
</code>
1.5 trim()該函數(shù)由自己實(shí)現(xiàn)
<code>
std::string& trim(std::string &s)
{
if (s.empty())
{
return s;
}
s.erase(0,s.find_first_not_of(" "));
s.erase(s.find_last_not_of(" ") + 1);
return s;
}
</code>
2. vector
定義:
vector<類型> v虫蝶;
插入:
尾部插入: v.push_back(a);
普通插入:v.insert(v.begin()+i,a);在第i+1個(gè)元素前面插入a
刪除:
刪除元素: v.erase(v.begin()+2);刪除第3個(gè)元
清空: v.clear();
遍歷:
使用下標(biāo)訪問(wèn)元素:
cout<<v[0]<<endl;記住下標(biāo)是從0開(kāi)始的
使用迭代器訪問(wèn)元素:
vector<int>::iterator it;
for(it=v.begin();it!=v.end();it++)
cout<<*it<<endl;
大小:
向量大小:v.size();
3.map
定義:
map<類型,類型> m倦西;
map<int ,string>maplive;
map<int ,string >::iterator l_it;
查詢:
l_it=maplive.find(112);
if(l_it==maplive.end())
cout<<"we do not find112"<<endl;
else
cout<<"wo find112"<<endl;
插入:
1.maplive.insert(pair<int,string>(102,"aclive"));
2.maplive.insert(map<int,string>::value_type(321,"hai"));
3.maplive[112]="April";//map中最簡(jiǎn)單最常用的插入添加能真!
刪除:
l_it =maplive.find(112);
if( l_it == maplive.end())
cout<<"we do not find112"<<endl;
else
maplive.erase(l_it);//delete 112;
遍歷:
for(l_it=maplive.begin();l_it!=maplive.end();l_it++)
cout<<"key:"<<l_it->first<<"value:"<<l_it->second<<endl;
大小:
maplive.size();
4.stack
定義:
stack<類型> s扰柠;
stack<string> st;
插入:
string x;
st.push(x);
刪除:
st.pop();出棧操作只是刪除棧頂元素粉铐,并不返回該元素。
判空:
st.empty();
大新钡怠:
st.size();
訪問(wèn):
st.top();訪問(wèn)棧頂元素蝙泼;
5.queue
定義:
queue<類型> q;
queue<string>qu;
插入:
string x;
qu.push(x);
刪除:
qu.pop();彈出隊(duì)列的第一個(gè)元素劝枣,并不會(huì)返回被彈出的元素值汤踏;
遍歷:
qu.front() : 訪問(wèn)隊(duì)首元素
qu.back() : 訪問(wèn)隊(duì)尾元素
大小:
qu.size()
6.文件的輸入
<code>
void ReadDataFromFileLBLIntoCharArray()
{
cout<< "逐行讀取, 將行讀入字符數(shù)組, 行之間用回車(chē)換行區(qū)分" << endl;
ifstream fin("file.txt")
const int LINE_LENGTH=100;
char str[LINE_LENGTH];
while(fin.getline(str,LINE_LENGTH))
{
cout << str << endl;
}
fin.close();
}
</code>