當前位置: 首頁>>代碼示例 >>用法及示例精選 >>正文


C++ Algorithm stable_partition()用法及代碼示例


C++算法stable_partition()函數用於對[first, last)範圍內的元素進行分類,使得所有pred返回true的元素先於所有返回false的元素,保留元素的相對順序。

注意:- 此函數通常使用內部臨時緩衝區來實現。

用法

template <class BidirectionalIterator, class UnaryPredicate>
BidirectionalIterator stable_partition (BidirectionalIterator first,
BidirectionalIterator last,
UnaryPredicate pred);

參數

first: 一個雙向迭代器,指向要分區的範圍內的第一個元素。

last:一個雙向迭代器,指向要分區的範圍中過去的最後一個元素。

pred: 用戶定義的一元謂詞函數,它定義要對元素進行分類時要滿足的條件。

返回值

此函數返回一個迭代器,指向不滿足謂詞條件的範圍的第一個元素。

複雜度

如果有足夠的內存可用,複雜性在 [first, last) 範圍內是線性的:將 pred 應用於每個元素。

數據競爭

範圍 [first, last) 中的對象被修改。

異常

如果任何元素的比較、元素交換或迭代器上的操作引發異常,則此函數將引發異常。

請注意,無效參數會導致未定義的行為。

例子1

讓我們看一個簡單的例子來演示 stable_partition() 的使用:

#include <iostream>     // std::cout
#include <algorithm>    // std::stable_partition
#include <vector>       // std::vector

using namespace std;

bool IsOdd (int i) { return (i%2)==1; }

int main () {
  vector<int> myvector;

  // set some values:
  for (int i=1; i<10; ++i) myvector.push_back(i); // 1 2 3 4 5 6 7 8 9

  vector<int>::iterator bound;
  bound = stable_partition (myvector.begin(), myvector.end(), IsOdd);

  // print out content:
  cout << "odd elements:";
  for (vector<int>::iterator it=myvector.begin(); it!=bound; ++it)
    cout << ' ' << *it;
  cout << '\n';

  cout << "even elements:";
  for (vector<int>::iterator it=bound; it!=myvector.end(); ++it)
    cout << ' ' << *it;
  cout << '\n';

  return 0;
}

輸出:

odd elements:1 3 5 7 9
even elements:2 4 6 8

在上麵的例子中,從 1 到 9 的元素被劃分為偶數和奇數元素。

例子2

讓我們看另一個簡單的例子:

#include <vector>  
#include <algorithm>  
#include <iostream>  
  
bool greater5 ( int value ) {  
   return value >5;  
}  
  
int main( ) {  
   using namespace std;  
   vector <int> v1, v2;  
   vector <int>::iterator Iter1, Iter2, result;  
  
   int i;  
   for ( i = 0 ; i <= 10 ; i++ )  
      v1.push_back( i );  
  
   int ii;  
   for ( ii = 0 ; ii <= 4 ; ii++ )  
      v1.push_back( 5 );  
  
   random_shuffle(v1.begin( ), v1.end( ) );  
  
   cout << "Vector v1 is ( " ;  
   for ( Iter1 = v1.begin( ) ; Iter1 != v1.end( ) ; Iter1++ )  
      cout << *Iter1 << " ";  
   cout << ")." << endl;  
  
   // Partition the range with predicate greater10  
   result = stable_partition (v1.begin( ), v1.end( ), greater5 );  
   cout << "The partitioned set of elements in v1 is:\n ( " ;  
   for ( Iter1 = v1.begin( ) ; Iter1 != v1.end( ) ; Iter1++ )  
      cout << *Iter1 << " ";  
   cout << ")." << endl;  
  
   cout << "The first element in v1 to fail to satisfy the"  
        << "\n predicate greater5 is:" << *result << "." << endl;  
        
        return 0;
}

輸出:

Vector v1 is ( 4 10 5 5 5 5 5 1 6 9 3 7 8 2 0 5 ).
The partitioned set of elements in v1 is:
 ( 10 6 9 7 8 4 5 5 5 5 5 1 3 2 0 5 ).
The first element in v1 to fail to satisfy the
 predicate greater5 is:4.

例子3

讓我們看另一個使用 partition() 函數快速排序向量元素的簡單示例:

#include <iostream>
#include <algorithm>
#include <vector>

using namespace std;
 
int main()
{
    vector<int> v{0, 0, 3, 0, 2, 4, 5, 0, 7};
    stable_partition(v.begin(), v.end(), [](int n){return n>0;});
    for (int n:v) {
        cout << n << ' ';
    }
    cout << '\n';
    
    return 0;
}

輸出:

3 2 4 5 7 0 0 0 0

示例 4

讓我們看另一個簡單的例子:

#include <iostream>
#include <vector>
#include <algorithm>

using namespace std;

int main()
{
  vector<int> v = {1, 0, 3, 4, 5, 6, 12, 7, 9};

  stable_partition(v.begin(), v.end(), [](int x) { return x % 3 == 0; });

  for_each(v.begin(), v.end(), [](int x) {
   cout << x << endl;
  });
  
  return 0;
}

輸出:

0
3
6
12
9
1
4
5
7





相關用法


注:本文由純淨天空篩選整理自 C++ Algorithm stable_partition()。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。