遍历方式一,下标+[ ]
for(size_t i=0;i<s2.size();++i) //s.size()返回字符串的长度
{
cout<<s2[i]<<" ";
}
cout<<endl;
拓展小知识:
迭代器的意义:像string、vector支持[ ]遍历,但list、map等容器不支持[ ],此时就要用迭代器遍历,所以迭代器是一种统一使用的方式。
//正向迭代器
string::iterator it=s2.begin();
while(it!=s2.end())
{
cout<<*it<<" ";
++it;
}
cout<<endl;
//反向迭代器
string::reverse_iterator rit=s3.rbegin();
while(it!=s3.rend())
{
cout<<*rit<<" ";
++rit;//注意不是--rit
}
cout<<endl;
//正向迭代器中普通对象使用iterator,const对象使用const_iterator
//反向迭代器中普通对象使用reverse_iterator,const对象使用const_reverse_iterator
end返回的不是最后一个数据的位置,返回的是最后一个位置的下一个位置,所以上面代码中得用 “!=”
遍历方式三,(C++11提供)范围for
特点:写起来非常简洁。
//依次取容器中的数据,赋值给e,自动判断结束
for(auto e: s3) //auto也可改为s3的类型,如char
{ //e也可以修改,其为变量名称
cout<<e<<" "; //不可修改e的值
}
cout<<endl;
//可修改e的值的方式
for(auto& e: s3)
{
e+=1; //此时可修改e,上面代码中为复制拷贝,故不可修改;此处为别名引用,便可修改其值
}