首頁 >後端開發 >C++ >如何根據使用者輸入在 C 中建立動態二維數組?

如何根據使用者輸入在 C 中建立動態二維數組?

Patricia Arquette
Patricia Arquette原創
2024-12-08 22:25:11853瀏覽

How Can I Create Dynamic Two-Dimensional Arrays in C   Based on User Input?

依照使用者輸入聲明動態二維數組

簡介

建立動態二維數組,可以依照使用者輸入進行客製化給C 編程帶來了挑戰。雖然陣列通常在聲明時具有固定大小,但此特定任務需要靈活地確定大小。讓我們探索動態分配和操作此類數組的不同方法。

向量的向量方法

向量的向量(向量)可以服務作為動態建立矩陣的解。在這種方法中,每個內部向量代表矩陣的一行,而外部向量則充當這些行的容器。只需修改外部向量的大小即可調整矩陣的大小。

int n;
cin >> n;
vector<vector<int>> matrix(n, vector<int>(n));

自訂矩陣類別

另一種選擇是實現自訂矩陣封裝了動態管理二維陣列的功能的類別。這種方法提供了對資料結構的更多控制,並允許高效的記憶體管理。

template <class T>
class Matrix {
  int columns_;
  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]; }
};

運算子[]的多重重載

也可以實現動態使用運算子[]的多個重載的二維數組。這種方法利用代理來間接存取數據,提供類似傳統數組存取的語法。

template<class T, int size>
class Matrix3 {
  T data[size][size][size];
  class Proxy { Matrix3& m_; int index1_, index2_; };
  class Proxy2 { Matrix3& m_; int index_; };
public:
  Proxy2 operator[](int index) { return Proxy2(*this, index); }
  Proxy operator[](int index1, int index2) { return Proxy(*this, index1, index2); }
};

結論

每種方法都提供不同程度的靈活性、效率,並且易於實施。向量的向量方法很簡單,但由於存在多個間接級別,可能會對效能產生影響。自訂矩陣類別提供了對記憶體管理和靈活性的更多控制。 Operator[] 方法的多重重載允許使用熟悉的語法存取元素,但需要更複雜的實作。最終,選擇取決於應用程式的特定要求。

以上是如何根據使用者輸入在 C 中建立動態二維數組?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn