2차원 std::벡터의 최적 초기화
다차원 std::벡터 초기화는 특히 효율적인 작업을 목표로 할 때 특정 과제를 제시합니다. 암호. 주어진 예를 생각해 보십시오.
std::vector<std::vector<int>> fog; for (int i = 0; i < A_NUMBER; i++) { std::vector<int> fogRow; for (int j = 0; j < OTHER_NUMBER; j++) { fogRow.push_back(0); } fog.push_back(fogRow); }
이 접근 방식에는 여러 개의 중첩 루프가 필요하며 다소 지루해 보입니다. std::벡터::벡터(count, value) 생성자를 사용하는 더 최적의 솔루션이 있습니다.
std::vector<std::vector<int>> fog( ROW_COUNT, std::vector<int>(COLUMN_COUNT)); // Defaults to zero initial value
이 경우 생성자는 초기 크기와 기본값을 사용합니다. 다른 기본값을 원하는 경우 다음과 같이 지정할 수 있습니다.
std::vector<std::vector<int>> fog( ROW_COUNT, std::vector<int>(COLUMN_COUNT, 4));
게다가 C 11에 도입된 균일한 초기화를 활용하면 벡터 초기화를 위한 간결하고 읽기 쉬운 방법이 제공됩니다.
std::vector<std::vector<int>> fog { { 1, 1, 1 }, { 2, 2, 2 } };
위 내용은 C에서 2D std::Vector의 초기화를 어떻게 최적화할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!