Rumah >pembangunan bahagian belakang >C++ >Bagaimanakah Saya Boleh Memulakan std::vektor 2D dengan Cekap dalam C ?

Bagaimanakah Saya Boleh Memulakan std::vektor 2D dengan Cekap dalam C ?

Linda Hamilton
Linda Hamiltonasal
2024-12-02 22:52:14798semak imbas

How Can I Efficiently Initialize a 2D std::vector in C  ?

Memulakan std::vector 2D dengan cekap

Memulakan std::vector dua dimensi boleh menjadi tugas yang menyusahkan. Pendekatan biasa ialah membuat dan menambahkan baris secara manual pada vektor, seperti yang ditunjukkan oleh kod yang disediakan. Walau bagaimanapun, kaedah ini boleh menjadi tidak cekap dan terdedah kepada ralat.

Penyelesaian alternatif ialah memanfaatkan pembina std::vector::vector(count, value). Pembina ini menerima dua parameter: bilangan baris yang dikehendaki dan nilai lalai untuk setiap elemen baris. Dengan menentukan nilai yang sesuai untuk parameter ini, kita boleh memulakan vektor dalam satu pernyataan:

std::vector<std::vector<int>> fog(ROW_COUNT, std::vector<int>(COLUMN_COUNT)); // Defaults to zero initial value

Jika nilai lalai selain sifar dikehendaki, ia boleh ditentukan sebagai argumen kedua kepada pembina:

std::vector<std::vector<int>> fog(ROW_COUNT, std::vector<int>(COLUMN_COUNT, 4));

Permulaan Seragam

C 11 memperkenalkan pakaian seragam permulaan, menyediakan satu lagi sintaks ringkas untuk memulakan vektor 2D:

std::vector<std::vector<int>> fog { { 1, 1, 1 },
                                    { 2, 2, 2 } };

Pendekatan ini menggunakan pendakap kerinting untuk memulakan baris dalam vektor. Setiap senarai tertutup pendakap kerinting dalam mewakili satu baris, dengan setiap elemen dimulakan kepada nilai yang ditentukan.

Dengan menggunakan teknik ini, kami boleh memulakan std::vektor 2D dengan cekap dan elegan, mengelakkan kerumitan pemulaan manual .

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Memulakan std::vektor 2D dengan Cekap dalam C ?. 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