二維陣列new小結

2021-09-12 17:45:58 字數 764 閱讀 4714

a (*ga)[n] = new a[m][n];

…delete ga;

缺點:n必須是已知

優點:呼叫直觀,連續儲存,程式簡潔(經過測試,析構函式能正確呼叫)

a** ga = new a*[m];

for(int i = 0; i < m; i++)

ga[i] = new a[n];

…for(int i = 0; i < m; i++)

delete ga[i];

delete ga;

缺點:非連續儲存,程式煩瑣,ga為a**型別

優點:呼叫直觀,n可以不是已知

a* ga = new a[m*n];

…delete ga;

缺點:呼叫不夠直觀

優點:連續儲存,n可以不是已知

vector > ga;

ga.resize(m); //這三行可用可不用

for(int i = 1; i < n; i++) //

ga[i].resize(n); //

…vector ga;

ga.resize(m*n);

方法3,4的結合

2的改進版

a** ga = new a*[m];

ga[0] = new a[m*n];

for(int i = 1; i < m; i++)

ga[i] = ga[i-1]+n;

優點:連續儲存,n可以不是已知,析構方便,猜想只需delete ga;

參考:

zt 二維陣列new小結

轉至水木清華 1.a ga n new a m n delete ga 缺點 n必須是已知 優點 呼叫直觀,連續儲存,程式簡潔 經過測試,析構函式能正確呼叫 2.a ga new a m for int i 0 i m i ga i new a n for int i 0 i m i delete ...

C 中二維陣列new小結

二維陣列new小結 轉至水木清華 1.a ga n new a m n delete ga 缺點 n必須是已知 優點 呼叫直觀,連續儲存,程式簡潔 經過測試,析構函式能正確呼叫 2.a ga new a m for int i 0 i m i ga i new a n for int i 0 i m...

C 二維陣列new小結 zz

c 二維陣列new小結 zz 1.a ga n new a m n delete ga 缺點 n必須是已知 優點 呼叫直觀,連續儲存,程式簡潔 經過測試,析構函式能正確呼叫 2.a ga new a m for int i 0 i m i ga i new a n for int i 0 i m i...