vector<int> *p 与 vector<int *> p 的区别?
好像感觉第二种迭代操作时比较直观一些,但是不知道第一种怎么进行迭代操作?谁能演示一个给我看,按下面的代码来修改:#include<iostream>#include<ve...
好像感觉第二种迭代操作时比较直观一些,但是不知道第一种怎么进行迭代操作?谁能演示一个给我看,按下面的代码来修改: #include <iostream>
#include <vector>
using namespace std;int main()
{
vector<int *> p;
int a=5,b=7;
p.push_back(&a);
p.push_back(&b);
vector<int *>::iterator iter=p.begin();
while(iter!=p.end())
cout<<**iter++<<endl;
system("pause");
return 0;
} 展开
#include <vector>
using namespace std;int main()
{
vector<int *> p;
int a=5,b=7;
p.push_back(&a);
p.push_back(&b);
vector<int *>::iterator iter=p.begin();
while(iter!=p.end())
cout<<**iter++<<endl;
system("pause");
return 0;
} 展开
1个回答
2013-07-07
展开全部
第一种方式vector<int> *p 不行吧?这个相当于是一个vector<int>的数组了……个人感觉只能这样搞:#include <iostream>
#include <vector>
using namespace std;int main()
{
vector<int> p;
int a=5,b=7;
p.push_back(a);
p.push_back(b);
vector<int>::iterator iter=p.begin();
while(iter!=p.end())
cout<<*iter++<<endl;
system("pause");
return 0;
}
第二种方式vector<int*> p则是一个整型指针的向量vector,所以存入的&a,&b则是对应整型的地址,然后用指针迭代器来访问。cout<<**iter++<<endl;有两个*,是因为*p表示的是整型的地址,*(*p)则是它的值。
#include <vector>
using namespace std;int main()
{
vector<int> p;
int a=5,b=7;
p.push_back(a);
p.push_back(b);
vector<int>::iterator iter=p.begin();
while(iter!=p.end())
cout<<*iter++<<endl;
system("pause");
return 0;
}
第二种方式vector<int*> p则是一个整型指针的向量vector,所以存入的&a,&b则是对应整型的地址,然后用指针迭代器来访问。cout<<**iter++<<endl;有两个*,是因为*p表示的是整型的地址,*(*p)则是它的值。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询