많은 프로그래밍 시나리오에서는 컴파일 시 알 수 없는 크기의 배열이나 행렬을 생성해야 합니다. 시간. 배열은 일반적으로 고정된 크기를 가지므로 이는 문제가 됩니다. 그러나 C는 런타임에 메모리를 동적으로 할당하는 메커니즘을 제공하므로 사용자 입력에 따른 크기의 배열을 생성할 수 있습니다.
동적 2차원 메모리를 생성하는 한 가지 접근 방식 배열은 벡터의 벡터를 활용하는 것입니다. 여기에는 다른 벡터를 저장하는 벡터를 정의하여 행렬 구조를 효과적으로 생성하는 작업이 포함됩니다. 예:
std::vector<std::vector<int>> matrix(N);
이렇게 하면 내부 벡터의 각 요소가 행렬의 셀을 나타내는 NxN 행렬이 생성됩니다. 그러나 각 내부 벡터의 크기를 개별적으로 조정하거나 값을 할당해야 하므로 다른 방법에 비해 메모리 효율성이 떨어집니다.
대안 접근 방식은 행렬 표현을 추상화하고 동적 메모리 할당을 처리하는 래퍼 클래스를 만드는 것입니다. 예는 다음과 같습니다.
template <class T> class Matrix { int columns_; std::vector<T> data; public: Matrix(int columns, int rows) : columns_(columns), data(columns * rows) {} T& operator()(int column, int row) { return data[row * columns_ + column]; } };
이 클래스는 T 유형의 동적 행렬을 정의합니다. 여기서 생성자는 열과 행의 수를 할당하고 연산자() 함수는 직관적인 사용을 통해 행렬 요소에 대한 액세스를 제공합니다. 행 및 열 인덱스.
또 다른 기술은 배열 첨자 연산자([])를 오버로드하는 것입니다. 이를 통해 익숙한 구문을 사용하여 행렬 요소에 액세스할 수 있습니다.
class Matrix { int columns_; std::vector<T> data; public: Matrix(int columns, int rows) : columns_(columns), data(columns * rows) {} T& operator[](const std::pair<int, int>& indices) { return data[indices.first * columns_ + indices.second]; } };
이 접근 방식을 사용하면 다음을 통해 행렬 요소에 액세스할 수 있습니다.
T& element = matrix[std::make_pair(row, column)];
방법 선택은 특정 항목에 따라 다릅니다. 상황 및 성능 요구 사항. 벡터의 벡터, 래퍼 클래스 또는 연산자 오버로딩을 활용하든 이러한 기술은 C에서 동적 2차원 배열을 생성하고 조작할 수 있는 유연성을 제공합니다.
위 내용은 사용자 입력을 기반으로 C에서 동적으로 크기가 조정된 2차원 배열을 어떻게 만들 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!