list<> 中find的使用

昨天要在 std::list<std::string> 中判断是否存在某一字符串 std::string 。

 

我首先想到的是 list迭代+std::string重载的"==" 判断,也就是

    list<string>  listStr;
    string  s1; 
    for(vector<string>::iterator           itr=listStr.begin();itr!=listStr.end();itr++)
    {
        if(*itr==s1) break; 
    }
      
    if(itr!=**.end())
    {
        //干点什么
    }        

 

这种,但觉得有点麻烦,想到了list有find的,就去查了一下,测试过后得到下面的情况:

 

  

    list<string> listStr;
    string s1;
    list<string>::iterator lsItr=find(listStr.begin();listStr.end();s1);
    if(lsItr!=vetStr.end())
    {
          //干点什么
    }

    不过这里要注意 使用std的find时要 加上 #include<algorithm> 头文件

 

  

posted @ 2014-06-13 09:21  不笑猫  阅读(6477)  评论(0编辑  收藏  举报