Rumah >pembangunan bahagian belakang >C++ >Bagaimana untuk Mencerap Berbilang Bekas C dengan Cekap Secara serentak?

Bagaimana untuk Mencerap Berbilang Bekas C dengan Cekap Secara serentak?

Susan Sarandon
Susan Sarandonasal
2024-12-05 21:04:10945semak imbas

How to Efficiently Iterate Over Multiple C   Containers Simultaneously?

Lelaran Serentak Pada Berbilang Bekas dalam C

C 11 menawarkan pelbagai mekanisme untuk lelaran ke atas bekas, termasuk gelung berasaskan julat dan 'std ::untuk_setiap' fungsi. Walau bagaimanapun, persoalan timbul: apakah pendekatan yang disyorkan untuk mengulangi dua atau lebih bekas yang sama saiz untuk melakukan tindakan yang serupa dengan yang berikut:

for (unsigned i = 0; i < containerA.size(); ++i) {
  containerA[i] = containerB[i];
}

Menggunakan Indeks dengan Gelung Berasaskan Julat

Penyelesaian yang cekap melibatkan lelaran ke atas indeks bekas menggunakan gelung berasaskan julat. Pendekatan ini memberikan tahap kecekapan yang sama seperti gelung klasik. Coretan kod di bawah menunjukkan kaedah ini:

for (unsigned i : indices(containerA)) {
    containerA[i] = containerB[i];
}

Fungsi 'indeks' mengembalikan julat indeks yang dinilai dengan malas untuk bekas. Pelaksanaannya tersedia di GitHub.

Mengzip Bekas

Jika corak ini kerap berlaku dalam data anda, pendekatan alternatif adalah dengan mengezip bekas, mencipta julat tupel yang elemennya sepadan dengan elemen berpasangan:

for (auto& [a, b] : zip(containerA, containerB)) {
    a = b;
}

Fungsi 'zip' boleh dilaksanakan dengan mudah berdasarkan fungsi 'indeks'.

Pendekatan ini juga menyediakan lelaran yang cekap, dan ia merupakan penyelesaian yang lebih ringkas dan boleh dibaca dalam kes tertentu.

Atas ialah kandungan terperinci Bagaimana untuk Mencerap Berbilang Bekas C dengan Cekap Secara serentak?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn