1.string
string的定义,初始化,遍历等基础在此略去。
常用的string类型的操作
substr()
replace()
find()
split()
trim()
1.1 substr()
s.substr(pos,n)该函数截取s字符串从pos开始计算共n个,然后返回该子串。该函数由string类库提供
1.2 replace()
s.replace(pos,len,args)该函数删除s中从下表pos开始的len个字符,用args指定的字符替换。
然后返回s的引用。该函数也由string类库提供
1.3 find()
s.find(args,pos)该函数从s的pos位置开始查找args第一次出现的位置并返回该值。
该函数也由string类库提供。
1.4 split()该函数由自己实现
<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()该函数由自己实现
<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个元素前面插入a
删除:
删除元素: v.erase(v.begin()+2);删除第3个元
清空: v.clear();
遍历:
使用下标访问元素:
cout<<v[0]<<endl;记住下标是从0开始的
使用迭代器访问元素:
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中最简单最常用的插入添加!
删除:
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();
访问:
st.top();访问栈顶元素;
5.queue
定义:
queue<类型> q;
queue<string>qu;
插入:
string x;
qu.push(x);
删除:
qu.pop();弹出队列的第一个元素,并不会返回被弹出的元素值;
遍历:
qu.front() : 访问队首元素
qu.back() : 访问队尾元素
大小:
qu.size()
6.文件的输入
<code>
void ReadDataFromFileLBLIntoCharArray()
{
cout<< "逐行读取, 将行读入字符数组, 行之间用回车换行区分" << 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>