Login | Register   
RSS Feed
Download our iPhone app
Browse DevX
Sign up for e-mail newsletters from DevX

By submitting your information, you agree that devx.com may send you DevX offers via email, phone and text message, as well as email offers about other products and services that DevX believes may be of interest to you. DevX will process your information in accordance with the Quinstreet Privacy Policy.

Tip of the Day
Language: C++
Expertise: Advanced
Dec 19, 2000



Building the Right Environment to Support AI, Machine Learning and Deep Learning

The remove_if() algorithm

The remove_if() algorithms (defined in the standard header <algorithm>) has the following prototype:
template <class ForwardIterator, class T>
ForwardIterator  remove (ForwardIterator first,
                         ForwardIterator last,
                         Predicate pred);

The first two arguments mark the sequence's beginning and end. The third argument is a predicate. Unlike remove(), remove_if() uses the predicate provided to select the elements it removes. This enables you to remove elements with different values that fall under the same category, e.g., odd numbers, vowels, uppercase letters etc. Using remove_if() is similar to using remove(). The tricky part in is the definition of the predicate. A concrete example will clarify this issue.

Suppose we want to remove all the vowels from a string object. Our predicate has to distinguish between a vowel and a non-vowel. We define the is_vowel predicate as follows:

template <class T> 
class is_vowel: public unary_function
 bool operator ()(T t) const
  if ((t=='a')||(t=='e')||(t=='i')||(t=='o')||(t=='u'))
   return true; //t is a vowel
  return false; // t is not a vowel

Our goal is to read a string from the standard input, remove all the vowels therein by using remove_if(), and display the resulting vowel-less string. The first part is straightforward:

#include <string>
#include <iostream> 
#include <algorithm> // for remove_if
using namespace std;

int main()
 string original;
 cin >> original;
Danny Kalev
Comment and Contribute






(Maximum characters: 1200). You have 1200 characters left.



Thanks for your registration, follow us on our social networks to keep up-to-date