c++中vector和find的用法,一个小问题,急死人啊
我有一个向量vector<int>了,里面存有若干整数,假如这个向量叫Prime,我想判断一个数12是否在Prime中,可不可以用#include<algorithm>里...
我有一个向量vector<int>了,里面存有若干整数,假如这个向量叫Prime,我想判断一个数12是否在Prime中,可不可以用#include<algorithm>里的find()函数呢
即:Prime.find(12)是否可行,如果可行,我还想得到12在Prime中的位置,该如何操作呢? 展开
即:Prime.find(12)是否可行,如果可行,我还想得到12在Prime中的位置,该如何操作呢? 展开
4个回答
展开全部
用迭代器就可以了。
vector< int >::iterator iter = prime.begin();
for ( ; iter != prime.end(); ++iter )
if(*iter == 12)
{
//find it out
}
另外如果你要用algorithm的find,也不是prime.find()这样用的。而是find(prime.begin(),prime.end(),search_value);其中search_value是12. 大致语法如下,
vector<int>::iterator found;
found = find( vec.begin(), vec.end(), search_value );
if ( found != vec.end() )
cout << "search_value found!\n";
else cout << "search_value not found!\n";
可参考C++ Primer中文第3版的58页
vector< int >::iterator iter = prime.begin();
for ( ; iter != prime.end(); ++iter )
if(*iter == 12)
{
//find it out
}
另外如果你要用algorithm的find,也不是prime.find()这样用的。而是find(prime.begin(),prime.end(),search_value);其中search_value是12. 大致语法如下,
vector<int>::iterator found;
found = find( vec.begin(), vec.end(), search_value );
if ( found != vec.end() )
cout << "search_value found!\n";
else cout << "search_value not found!\n";
可参考C++ Primer中文第3版的58页
展开全部
所有容器只有string提供了find操作.
vector<>只能使用algorithm里的find系列,和search系列.
vector<>只能使用algorithm里的find系列,和search系列.
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
vector<int>::iterator iter;
iter=find(primevec.begin(),primevec.end(),n);
if(iter!=primevec.end())
cout<<iter-primevec.begin()+1<<endl;
else cout<<'0'<<endl;
iter=find(primevec.begin(),primevec.end(),n);
if(iter!=primevec.end())
cout<<iter-primevec.begin()+1<<endl;
else cout<<'0'<<endl;
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这么写:
if ( find(Prime.begin(), Prime.end(), 12) == Prime.end())
{
// 没找到
} else {
// 找到了。
}
参照: http://en.cppreference.com/w/cpp/algorithm/find
if ( find(Prime.begin(), Prime.end(), 12) == Prime.end())
{
// 没找到
} else {
// 找到了。
}
参照: http://en.cppreference.com/w/cpp/algorithm/find
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询