std::is_permutation
| Definiert in Header <algorithm> |
||
| template< class ForwardIt1, class ForwardIt2 > bool is_permutation( ForwardIt1 first1, ForwardIt1 last1, |
(1) | (seit C++11) (constexpr seit C++20) |
| template< class ForwardIt1, class ForwardIt2, class BinaryPredicate > |
(2) | (seit C++11) (constexpr seit C++20) |
| template< class ForwardIt1, class ForwardIt2 > bool is_permutation( ForwardIt1 first1, ForwardIt1 last1, |
(3) | (seit C++14) (constexpr seit C++20) |
| template< class ForwardIt1, class ForwardIt2, class BinaryPredicate > |
(4) | (seit C++14) (constexpr seit C++20) |
Prüft, ob [first1, last1) eine Permutation eines von first2 ausgehenden Bereichs ist.
- Für Überladungen (1,2) hat der zweite Bereich std::distance(first1, last1) Elemente.
- Für Überladungen (3,4) ist der zweite Bereich
[first2,last2).
Wenn ForwardIt1 und ForwardIt2 unterschiedliche Werttypen haben, ist das Programm ill-formed.
Wenn die Vergleichsfunktion keine Äquivalenzrelation ist, ist das Verhalten undefiniert.
Inhalt |
[edit] Parameter
| first1, last1 | - | das Iteratorenpaar, das den ersten Bereich der zu vergleichenden Elemente definiert. |
| first2, last2 | - | das Iteratorenpaar, das den zweiten Bereich der zu vergleichenden Elemente definiert. |
| p | - | binäre Prädikatfunktion, die true zurückgibt, wenn die Elemente als gleich behandelt werden sollen. Die Signatur der Prädikatfunktion sollte äquivalent zur folgenden sein: bool pred(const Type1 &a, const Type2 &b); Obwohl die Signatur nicht zwingend const & haben muss, darf die Funktion die ihr übergebenen Objekte nicht modifizieren und muss alle Werte vom Typ (möglicherweise const) |
| Typanforderungen | ||
-ForwardIt1, ForwardIt2 müssen die Anforderungen an LegacyForwardIterator erfüllen. | ||
[edit] Rückgabewert
true, wenn der Bereich [first1, last1) eine Permutation des Bereichs [first2, last2) ist, andernfalls false.
[edit] Komplexität
Sei N als std::distance(first1, last1)
) Vergleiche im Worst Case.
) Aufrufe im Worst Case.
) Vergleiche im Worst Case.
) Aufrufe im Worst Case.
[edit] Mögliche Implementierung
template<class ForwardIt1, class ForwardIt2> bool is_permutation(ForwardIt1 first, ForwardIt1 last, ForwardIt2 d_first) { // skip common prefix std::tie(first, d_first) = std::mismatch(first, last, d_first); // iterate over the rest, counting how many times each element // from [first, last) appears in [d_first, d_last) if (first != last) { ForwardIt2 d_last = std::next(d_first, std::distance(first, last)); for (ForwardIt1 i = first; i != last; ++i) { if (i != std::find(first, i, *i)) continue; // this *i has been checked auto m = std::count(d_first, d_last, *i); if (m == 0 || std::count(i, last, *i) != m) return false; } } return true; } |
[edit] Hinweis
std::is_permutation kann im Testing verwendet werden, insbesondere um die Korrektheit von neu arrangierenden Algorithmen (z. B. Sortieren, Mischen, Partitionieren) zu überprüfen. Wenn x ein ursprünglicher Bereich und y ein permutierter Bereich ist, dann bedeutet std::is_permutation(x, y) == true, dass y aus "denselben" Elementen besteht, möglicherweise an anderen Positionen.
[edit] Beispiel
#include <algorithm> #include <iostream> template<typename Os, typename V> Os& operator<<(Os& os, const V& v) { os << "{ "; for (const auto& e : v) os << e << ' '; return os << '}'; } int main() { static constexpr auto v1 = {1, 2, 3, 4, 5}; static constexpr auto v2 = {3, 5, 4, 1, 2}; static constexpr auto v3 = {3, 5, 4, 1, 1}; std::cout << v2 << " is a permutation of " << v1 << ": " << std::boolalpha << std::is_permutation(v1.begin(), v1.end(), v2.begin()) << '\n' << v3 << " is a permutation of " << v1 << ": " << std::is_permutation(v1.begin(), v1.end(), v3.begin()) << '\n'; }
Ausgabe
{ 3 5 4 1 2 } is a permutation of { 1 2 3 4 5 }: true
{ 3 5 4 1 1 } is a permutation of { 1 2 3 4 5 }: false[edit] Siehe auch
| erzeugt die nächstgrößere lexikographische Permutation eines Bereichs von Elementen (Funktionsvorlage) | |
| erzeugt die nächstkleinere lexikographische Permutation eines Bereichs von Elementen (Funktionsvorlage) | |
| (C++20) |
gibt an, dass eine Relation eine Äquivalenzrelation darstellt(Konzept) |
| (C++20) |
bestimmt, ob eine Sequenz eine Permutation einer anderen Sequenz ist (Algorithmus-Funktionsobjekt) |