C++教程
C++控制语句
C++函数
C++数组
C++指针
C++对象
C++继承
C++多态
C++抽象
C++常用
C++ STL教程
C++迭代器
C++程序

C++ remove()

C++ 算法remove()

C++ 算法 remove()函数用于从给定范围中消除所有等于val的元素[首先,last),而不会干扰其余元素的顺序。
此功能无法更改容器的大小。 它将迭代器返回到范围的新末端。 删除是稳定的,这意味着不等于val的元素的相对顺序保持不变。 此函数使用operator ==将各个元素与val进行比较。

语法

template <class ForwardIterator, class T>
ForwardIterator remove (ForwardIterator first, ForwardIterator last, const T& val);

参数

first: 前向迭代器,指向要删除元素范围内第一个元素的位置。
last: 前向迭代器,指向要从中删除元素的范围中的last元素的位置。
val : A

返回值

前向迭代器,它指向修改后的范围或第一个元素的新终止位置(last) first和last相等。

复杂度

复杂度在[first,last)范围内是线性的,并且可能对其中的一些进行赋值。

数据竞争

可以访问并可能修改[first,last)范围内的对象。

异常安全性

如果任何元素比较,元素分配或迭代器上的操作抛出ex,则此函数将引发异常
请注意,无效参数会导致未定义的行为。

示例1

让我们看一个简单的示例来演示使用remove():
#include <iostream>     // std::cout
#include <algorithm>    // std::remove
using namespace std;
int main () {
  int myints[] = {10,20,30,50,20,40,100,20};   
  // bounds of range:
  int* pbegin = myints;                          
  int* pend = myints+sizeof(myints)/sizeof(int); 
  pend = remove (pbegin, pend, 20);        
                                                 
  cout << "range contains:";
  for (int* p=pbegin; p!=pend; ++p)
    cout << ' ' << *p;
  cout << '\n';
  return 0;
}
输出:
range contains: 10 30 50 40 100

示例2

让我们看另一个简单的示例来说明delete()和remove()之间的区别:
#include <iostream>
#include <vector>
#include <algorithm>
int main()
{
  using namespace std;
  //Populate myvec with the data set 10, 5,-8, 5, 1, 4
  vector<int> myvec;
  myvec.push_back(10);
  myvec.push_back(5);
  myvec.push_back(-8);
  myvec.push_back(5);
  myvec.push_back(1);
  myvec.push_back(4);
  cout << "\n Initial data set: ";
  for(size_t i(0); i!=myvec.size(); ++i)
    cout << myvec.at(i) << ' ';
  //Remove the data elements matching '5'
  vector<int>::iterator invalid;
  invalid = remove( myvec.begin(), myvec.end(), 5 );
  cout << "\n\n Data set after remove: ";
  for(size_t i(0); i!=myvec.size(); ++i)
    cout << myvec.at(i) << ' ';
  //Destroy the remaining invalid elements
  myvec.erase( invalid, myvec.end() );
  cout << "\n\n Data set after erase:  ";
  for(size_t i(0); i!=myvec.size(); ++i)
    cout << myvec.at(i) << ' ';
    
    return 0;
}
输出:
  Initial data set: 10 5-8 5 1 4 
 Data set after remove: 10-8 1 4 1 4 
 Data set after erase:  10-8 1 4  

示例3

让我们看另一个简单的示例:
#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
bool IsOdd(int i) 
{ 
    return ((i % 2) == 1); 
} 
  
// Driver code 
int main ()  
{ 
    vector <int> vec1 { 10, 20, 30, 30, 20, 10, 10, 20}; 
      
    // Print original vector 
    cout << "Original vector : "; 
    for(int i=0; i < vec1.size(); i++) 
        cout << " " << vec1[i]; 
    cout << "\n"; 
  
    // Iterator that store the position of last element 
    vector <int>::iterator pend; 
      
    // std ::remove function call 
    pend = remove (vec1.begin(), vec1.end() , 20); 
      
    // Print the vector 
    cout << "After remove : "; 
    for ( vector<int> :: iterator p=vec1.begin(); p != pend; ++p) 
        cout << ' ' << *p; 
    cout << '\n'; 
    
    return 0;
}
输出:
Original vector :  10 20 30 30 20 10 10 20
After remove :  10 30 30 10 10

示例4

让我们看另一个简单的示例:
#include <vector>  
#include <algorithm>  
#include <iostream>  
  
int main( ) {  
   using namespace std;  
   vector <int> v1;  
   vector <int>::iterator Iter1, Iter2, new_end;  
  
   int i;  
   for ( i = 0 ; i <= 9 ; i++ )  
      v1.push_back( i );  
  
   int ii;  
   for ( ii = 0 ; ii <= 3 ; ii++ )  
      v1.push_back( 7 );  
  
   random_shuffle ( v1.begin( ), v1.end( ) );  
   cout << "Vector v1 is ( " ;  
   for ( Iter1 = v1.begin( ) ; Iter1 != v1.end( ) ; Iter1++ )  
      cout << *Iter1 << " ";  
   cout << ")." << endl;  
  
   // Remove elements with a value of 7  
   new_end = remove ( v1.begin( ), v1.end( ), 7 );  
  
   cout << "Vector v1 with value 7 removed is ( " ;  
   for ( Iter1 = v1.begin( ) ; Iter1 != v1.end( ) ; Iter1++ )  
      cout << *Iter1 << " ";  
   cout << ")." << endl;  
  
   // To change the sequence size, use erase  
   v1.erase (new_end, v1.end( ) );  
  
   cout << "Vector v1 resized with value 7 removed is ( " ;  
   for ( Iter1 = v1.begin( ) ; Iter1 != v1.end( ) ; Iter1++ )  
      cout << *Iter1 << " ";  
   cout << ")." << endl; 
   
   return 0;
}
输出:
Vector v1 is ( 4 7 7 7 0 5 7 1 6 9 3 7 8 2 ).
Vector v1 with value 7 removed is ( 4 0 5 1 6 9 3 8 2 9 3 7 8 2 ).
Vector v1 resized with value 7 removed is ( 4 0 5 1 6 9 3 8 2 ).

昵称: 邮箱:
Copyright © 2022 立地货 All Rights Reserved.
备案号:京ICP备14037608号-4