Mengzip Jujukan dalam C 11
Dengan pengenalan bagi gelung berasaskan julat dalam C 11, kod telah menjadi lebih ringkas dan boleh dibaca . Walau bagaimanapun, persoalan timbul sama ada ia boleh digunakan untuk mensimulasikan fungsi zip Python, yang berulang pada berbilang koleksi secara serentak.
Tingkatkan Fungsi Zip
Walaupun julat berasaskan untuk -gelung tidak menyokong gelung serentak secara langsung, perpustakaan Boost menyediakan zip_iterator. Ia membolehkan pengguna mentakrifkan julat yang berulang ke atas elemen daripada berbilang bekas secara selari.
Penggunaan Boost Zip_iterator
Coretan kod berikut menunjukkan cara menggunakan rangsangan:: zip_iterator:
#include <boost/iterator/zip_iterator.hpp> #include <vector> int main() { std::vector<int> a {1, 2, 3}; std::vector<std::string> b {"one", "two", "three"}; for (auto tup : boost::make_zip_iterator(boost::make_tuple(a.begin(), b.begin()))) { int x; std::string y; boost::tie(x, y) = tup; std::cout << x << " " << y << std::endl; } }
Kod ini akan output:
1 one 2 two 3 three
Amaran:
Adalah penting untuk ambil perhatian bahawa panjang semua bekas input mestilah sama. Jika tidak, tingkah laku yang tidak ditentukan mungkin berlaku.
Alternatif
Selain Boost, terdapat perpustakaan alternatif yang menawarkan fungsi zip untuk C . Sebagai contoh, pustaka Ranges menyediakan zip_view yang boleh digunakan dengan untuk gelung berasaskan julat:
#include <ranges> int main() { std::vector<int> a {1, 2, 3}; std::vector<std::string> b {"one", "two", "three"}; for (auto [x, y] : std::ranges::zip_view(a, b)) { std::cout << x << " " << y << std::endl; } }
Sama ada hendak menggunakan Boost atau perpustakaan lain bergantung pada keperluan khusus dan persediaan projek.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mensimulasikan Fungsi Zip Python Menggunakan C 11 dan Seterusnya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!