习题3.17 用迭代器而不是下标操作来访问vector中的元素,重做3.3.2节的习题.
//读一组整数到vector对象,计算并输出每对相邻元素的和
//使用迭代器访问vector中的元素
#include<iostream>
#include<vector>
using namespace std;
int main()
{
vector<int>ivec;
int ival;
//读入数据到vector对象
cout<<"Enter numbers(Ctrl+Z to end):"<<endl;
while(cin>>ival)
ivec.push_back(ival);
//计算相邻元素的和并输出
if(ivec.size()==0){
cout<<"No element?!"<<endl;
return -1;
}
cout<<"Sum of each pair of adjacent elements in the vector:"
<<endl;
vector<int>::size_type cnt=0;
for(vector<int>::iterator iter=ivec.begin();iter<ivec.end()-1;iter=iter+2){
cout<<*iter+*(iter+1)<<"/t";
++cnt;
if(cnt%6==0) //每行输出六个和
cout<<endl;
}
if(ivec.size()%2!=0) //提示最后一个元素没有求和
cout<<endl
<<"The last element is not been summed"
<<"and its value is"
<<*(ivec.end()-1)<<endl;
return 0;
}
//读一组整数到vector对象,计算首尾配对元素的和并输出
//使用迭代器访问vector中的元素
#include<iostream>
#include<vector>
using namespace std;
int main()
{
vector<int> ivec;
int val;
//读入数据到vector对象
cout<<"Enter numbers(Ctrl+Z to end):"<<endl;
while(cin>>ival)
ivec.push_back(ival);
//计算首尾配对元素的和并输出
if(ivec.size()==0){
cout<<"No element?!"<<endl;
return -1;
}
cout<<"Sum of each pair of counterpart element in the vector:"
<<endl;
vector<int>::size_type cnt=0;
for(vector<int>::iterator first=ivec.begin(),last=ivec.end()-1;first<last;++first,--last){
cout<<*first+*last<<"/t";
++cnt;
if(cnt%6==0) //每行输出六个和
cout<<endl;
}
if(first==last) //提示居中元素没有求和
cout<<endl
<<"The center element is not been summed"
<<"and its value is"
<<*first<<endl;
return 0;
}
重做3.14
//读入一段文本到vector对象,每个单词存储为vector中的一个元素
//把vector对象中每个单词转化为大写字母
//输出vector对象中转化后的元素,每8个单词为一行输出
//使用迭代器访问vector中的元素
#include<iostream>
#include<string>
#include<cctype>
#include<vector>
using namespace std;
int main()
{
vector<string> svec;
string str;
//读入文本到vector对象
cout<<"Enter text(Ctrl+Z to end):"<<endl;
while<cin>>str)
svec.push_back(str);
//将vector对象中每个单词转化为大写字母,并输出
if(svec.size()==0){
cout<<"No string?!"<<endl;
return -1;
}
cout<<"Transformed elements from the vector:"
<<endl;
vector<string>::size_type cnt=0;
for(vector<string>::iterator iter=svec.begin();iter!=svec.end();++iter){
for<string::size_type index=0;index!=(*iter).size();++index)
if(islower((*iter)[index]))
//单词中下标为index的字符为小写字母
(*iter)[index]=toupper((*iter)[index]);
cout<<*iter<<" ";
++cnt;
if(cnt%8==0) //每八个单词为一行输出
cout<<endl;
}
return 0;
}
习题3.18 编写程序来创建有10个元素的vector对象.用迭代器把每个元素值改为当前值的2倍
//创建有10个元素的vector对象
//然后使用迭代器将每个元素值改为当前值的2倍
#include<iostream>
#include<vector>
using namespace std;
int main()
{
vector<int> ivec(10,20); //每个元素的值均为20
//将每个元素值改为当前值的2倍
for(vector<int>::iterator iter=ivec.begin();iter!=ivec.end();++iter)
*iter=(*iter)*2;
return 0;
}
习题3.19 验证习题3.18的程序,输出vector的所有元素
//创建有10个元素的vector对象
//然后使用迭代器将每个元素值改为当前值的2倍
#include<iostream>
#include<vector>
using namespace std;
int main()
{
vector<int> ivec(10,20); //每个元素的值均为20
//将每个元素值改为当前值的2倍
for(vector<int>::iterator iter=ivec.begin();iter!=ivec.end();++iter)
*iter=(*iter)*2;
cout<<*iter<<" ";
}
return 0;
}
多了一句输出语句而已
习题3.20 解释一下在上面几个习题的程序实现中你使用了哪种迭代器,并说明原因.
使用了类型分别为vector<int>::iterator和vector<string>::iterator的迭代器,通过这些迭代器分别访问元素类型为int和string的vector对象中的元素
习题3.21 何时使用const迭代器的?又在何时使用const_iterator?解释两者的区别.
const迭代器是迭代器常量,该迭代器本身的值不能修改,即该迭代器在定义时需要初始化,而且初始化之后,不能再指向其他元素.若需要指向固定元素的迭代器,则可以使用const.
const_iterator是一种迭代器的类型,对这种类型的迭代器解引用会得到一个指向const对象的引用,即通过这种迭代器访问到的对象是常量.该对象不能修改,因此,const_iterator类型只能用于读取容器内的元素,不能修改元素的值.若只需遍历容器中的元素而无需修改它们,则可以使用const_iterator.