GSP
Quick Navigator

Search Site

Unix VPS
A - Starter
B - Basic
C - Preferred
D - Commercial
MPS - Dedicated
Previous VPSs
* Sign Up! *

Support
Contact Us
Online Help
Handbooks
Domain Status
Man Pages

FAQ
Virtual Servers
Pricing
Billing
Technical

Network
Facilities
Connectivity
Topology Map

Miscellaneous
Server Agreement
Year 2038
Credits
 

USA Flag

 

 

Man Pages
std::replace,std::replace_if(3) C++ Standard Libary std::replace,std::replace_if(3)

std::replace,std::replace_if - std::replace,std::replace_if


Defined in header <algorithm>
template< class ForwardIt, class T >


void replace( ForwardIt first, ForwardIt last, (until C++20)


const T& old_value, const T& new_value );
template< class ForwardIt, class T >


constexpr void replace( ForwardIt first, (since C++20)
ForwardIt last,


const T& old_value, const T& new_value );
template< class ExecutionPolicy, class
ForwardIt, class T >


void replace( ExecutionPolicy&& policy, (2) (since C++17)
ForwardIt first, ForwardIt last,


const T& old_value, const T& new_value );
template< class ForwardIt, class UnaryPredicate,
class T > (1)


void replace_if( ForwardIt first, ForwardIt (until C++20)
last,


UnaryPredicate p, const T& new_value );
template< class ForwardIt, class UnaryPredicate,
class T >


constexpr void replace_if( ForwardIt first, (3) (since C++20)
ForwardIt last,


UnaryPredicate p, const T& new_value );
template< class ExecutionPolicy, class
ForwardIt, class UnaryPredicate, class T >


void replace_if( ExecutionPolicy&& policy, (4) (since C++17)
ForwardIt first, ForwardIt last,


UnaryPredicate p, const T& new_value );


Replaces all elements satisfying specific criteria with new_value in the range
[first, last).


1) Replaces all elements that are equal to old_value.
3) Replaces all elements for which predicate p returns true.
2,4) Same as (1,3), but executed according to policy. These overloads do not
participate in overload resolution unless
std::is_execution_policy_v<std::decay_t<ExecutionPolicy>>
(until C++20)
std::is_execution_policy_v<std::remove_cvref_t<ExecutionPolicy>>
(since C++20) is true.


first, last - the range of elements to process
old_value - the value of elements to replace
policy - the execution policy to use. See execution policy for details.
unary predicate which returns true if the element value should be
replaced.


The expression p(v) must be convertible to bool for every argument v
p - of type (possibly const) VT, where VT is the value type of ForwardIt,
regardless of value category, and must not modify v. Thus, a parameter
type of VT&is not allowed
, nor is VT unless for VT a move is equivalent to a copy
(since C++11).
new_value - the value to use as replacement


-
ForwardIt must meet the requirements of LegacyForwardIterator.
-
UnaryPredicate must meet the requirements of Predicate.


(none)


Exactly last - first applications of the predicate.


The overloads with a template parameter named ExecutionPolicy report errors as
follows:


* If execution of a function invoked as part of the algorithm throws an exception
and ExecutionPolicy is one of the standard policies, std::terminate is called.
For any other ExecutionPolicy, the behavior is implementation-defined.
* If the algorithm fails to allocate memory, std::bad_alloc is thrown.


Because the algorithm takes old_value and new_value by reference, it can have
unexpected behavior if either is a reference to an element of the range [first,
last).


template<class ForwardIt, class T>
void replace(ForwardIt first, ForwardIt last,
const T& old_value, const T& new_value)
{
for (; first != last; ++first) {
if (*first == old_value) {
*first = new_value;
}
}
}


template<class ForwardIt, class UnaryPredicate, class T>
void replace_if(ForwardIt first, ForwardIt last,
UnaryPredicate p, const T& new_value)
{
for (; first != last; ++first) {
if(p(*first)) {
*first = new_value;
}
}
}


The following code at first replaces all occurrences of 8 with 88 in a vector of
integers. Then it replaces all values less than 5 with 55.

// Run this code


#include <algorithm>
#include <array>
#include <iostream>
#include <functional>


int main()
{
std::array<int, 10> s{5, 7, 4, 2, 8, 6, 1, 9, 0, 3};


std::replace(s.begin(), s.end(), 8, 88);


for (int a : s) {
std::cout << a << " ";
}
std::cout << '\n';


std::replace_if(s.begin(), s.end(),
std::bind(std::less<int>(), std::placeholders::_1, 5), 55);
for (int a : s) {
std::cout << a << " ";
}
std::cout << '\n';
}


5 7 4 2 88 6 1 9 0 3
5 7 55 55 88 6 55 9 55 55


replace_copy copies a range, replacing elements satisfying specific criteria
replace_copy_if with another value
(function template)
ranges::replace replaces all values satisfying specific criteria with another
ranges::replace_if value
(C++20) (niebloid)
(C++20)

2022.07.31 http://cppreference.com

Search for    or go to Top of page |  Section 3 |  Main Index

Powered by GSP Visit the GSP FreeBSD Man Page Interface.
Output converted with ManDoc.