在C ++编程STL中设置find()函数

在本文中,我们将讨论C ++ STL中的set::find()函数,其语法,工作原理和返回值。

C ++ STL中的设置是什么?

C ++ STL中的集合是必须按常规顺序具有唯一元素的容器。集必须具有唯一元素,因为元素的值标识该元素。一旦将值添加到集合容器中,以后就无法修改,尽管我们仍然可以将值删除或添加到集合中。集用作二进制搜索树。

设置了什么:: find()

find()函数是C ++ STL中的内置函数,在头文件中定义。此函数用于在设置的容器中查找元素或值。find()返回一个迭代器,该迭代器指向要搜索的元素的位置。如果该元素不存在于集合中,则它将在集合容器的最后一个元素之后返回该元素。

语法

Set1.find(const type_t&element);

参数

该函数接受一个参数,即要查找的元素。

返回值

该函数返回一个迭代器,该迭代器指向将要找到的元素。

示例

Input: set<int> myset = {10, 20, 40, 80, 90};
myset.find(40);
Output: element found

示例

#include <bits/stdc++.h>
using namespace std;
int main(){
   set<int> mySet;
   mySet.insert(10);
   mySet.insert(20);
   mySet.insert(90);
   mySet.insert(80);
   mySet.insert(40);
   auto temp = mySet.find(40);
   cout<<"Elements after 40 are: ";
   for (auto i = temp; i != mySet.end(); i++)
      cout << *i << " ";
   return 0;
}

输出结果

如果我们运行上面的代码,那么它将生成以下输出-

Elements after 40 are: 40 80 90

示例

#include <iostream>
#include <set>
int main (){
   std::set<int> mySet;
   std::set<int>::iterator i;
   for(int i=1; i<=4; i++)
      mySet.insert(i*2);
   i = mySet.find(6);
   mySet.erase(i);
   mySet.erase(mySet.find(4));
   std::cout<<"elements are : ";
   for (i = mySet.begin(); i != mySet.end(); ++i)
      std::cout << ' ' << *i;
   std::cout << '\n';
   return 0;
}

输出结果

如果我们运行上面的代码,那么它将生成以下输出-

Elements are : 2 8