Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                

C++ flat_set::count() Function



The std::flat_set::count() function in C++, is used to determine the number of elements in a flat_set that match the given key. Since the flat_set is a unique, sorted container, returns either 1 (if the key exists) or 0 (if it does not exists).

This function provides the efficient way to check for key existence without modifying the container. Unlike the std::map, which may stores duplicate keys, flat_set maintains only unique values.

Syntax

Following is the syntax for std::flat_set::find() function.

count( const Key& key ) const;

Parameters

  • key − It indicates the key value of the element to count.

Return Value

This function returns the number of elements with keyt that compare the equivalent to key.

Example 1

Let's look at the following example, where we are going to check for an existing element.

#include <iostream>
#include <boost/container/flat_set.hpp>
int main() {
   boost::container::flat_set < int > x = {2,4,6,8};
   int a = 6;
   if (x.count(a)) {
      std::cout << a << " is present in the set.\n";
   } else {
      std::cout << a << " is not present in the set.\n";
   }
   return 0;
}

Output

Output of the above code is as follows −

6 is present in the set.

Example 2

Consider the following example, where we are going to search for the element that does not exist and observing the output.

#include <iostream>
#include <boost/container/flat_set.hpp>
int main() {
   boost::container::flat_set < int > a = {1,3,5,7};
   int x = 15;
   if (a.count(x)) {
      std::cout << x << " is present in the set.\n";
   } else {
      std::cout << x << " is not present in the set.\n";
   }
   return 0;
}

Output

Following is the output of the above code −

15 is not present in the set.

Example 3

In the following example, we are going to use the count() inside the loop.

#include <iostream>
#include <boost/container/flat_set.hpp>
int main() {
   boost::container::flat_set < int > a = {1,2,5,3};
   for (int x = 1; x <= 5; x++) {
      if (a.count(x)) {
         std::cout << x << " is found in the set.\n";
      } else {
         std::cout << x << " is missing from the set.\n";
      }
   }
   return 0;
}

Output

If we run the above code it will generate the following output −

1 is found in the set.
2 is found in the set.
3 is found in the set.
4 is missing from the set.
5 is found in the set.
cpp_flat_set.htm
Advertisements