Meratakan Iterator dalam C
Pertimbangkan senario di mana anda mempunyai bekas bekas, seperti vektor
Dengan ketiadaan pelaksanaan peletakan iterator sedia ada dalam perpustakaan utama, kami membentangkan pelaksanaan asas di bawah:
#include <algorithm> #include <iostream> #include <set> #include <vector> template <typename OuterIterator> class flattening_iterator { public: // ... Iterator definitions and implementation private: void advance_past_empty_inner_containers() { // ... Advance logic } // ... Private members }; template <typename Iterator> flattening_iterator<Iterator> flatten(Iterator it) { // ... Return a flattening iterator for a single range } template <typename Iterator> flattening_iterator<Iterator> flatten(Iterator first, Iterator last) { // ... Return a flattening iterator for a range }
Pelaksanaan ini membolehkan anda untuk melelakan ke atas bekas bersarang dengan cara yang diratakan, seperti yang ditunjukkan dalam contoh berikut:
// Generate some test data std::vector<std::vector<int>> v(3); int i(0); for (auto it(v.begin()); it != v.end(); ++it) { it->push_back(i++); it->push_back(i++); it->push_back(i++); it->push_back(i++); } // Flatten the data and print all the elements for (auto it(flatten(v.begin(), v.end())); it != flatten(v.end()); ++it) { std::cout << *it << ", "; }
Pelaksanaan ini mempunyai belum diuji secara menyeluruh, dan ujian lanjut disyorkan sebelum memasukkannya ke dalam pengeluaran. Sekiranya anda menghadapi sebarang pepijat, sila hubungi pengarang untuk pembetulan.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mencipta Iterator Meratakan dalam C untuk Berulang di Atas Bekas Bersarang?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!