Maison >développement back-end >C++ >Comment puis-je trier plusieurs vecteurs en C tout en conservant la synchronisation à l'aide de Range-v3 ?
Tri des conteneurs verrouillés zippés en C à l'aide de Range-v3
Le défi
La tâche à portée de main implique de trier plusieurs vecteurs, ou conteneurs, tout en conservant leur ordre synchronisé. Idéalement, ce tri devrait s'effectuer sans copier les conteneurs dans un tuple ou une structure.
Solution Range-v3
Range-v3, une bibliothèque C moderne, fournit une solution pratique approche de ce problème. L'exemple suivant montre comment trier les conteneurs zippés à l'aide de ses fonctionnalités étendues :
#include <range/v3/all.hpp> #include <iostream> using namespace ranges; int main() { std::vector<int> a1{15, 7, 3, 5}; std::vector<int> a2{1, 2, 6, 21}; // Zip and sort the containers sort(view::zip(a1, a2), std::less< std::pair<int, int> >{}, &std::pair<int, int>::first); // Print the sorted vectors std::cout << view::all(a1) << '\n'; std::cout << view::all(a2) << '\n'; }
Exemple en direct
Explication
Conclusion
Cette solution Range-v3 offre un moyen élégant et efficace de trier plusieurs conteneurs verrouillés tout en préservant leur ordre synchronisé. Il met en évidence la puissance de Range-v3 pour résoudre des problèmes complexes de manipulation de données en C.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!