理解C/C 中的鋸齒狀數組
雖然鋸齒狀數組的概念(行可以有不同的長度)在標準C /C ,有一些技術可以實現類似的功能。
在嘗試聲明鋸齒狀C/C 中的數組如下所示:
<code class="c++">int jagged[][] = { {0,1}, {1,2,3} };</code>
編譯器出錯,突出顯示為除第一個維度之外的所有維度指定邊界的要求。為了克服這個限制,另一種方法是利用指標數組。
使用指標陣列建立鋸齒狀陣列
在 C 中,可以使用下列方式實現鋸齒狀陣列指標陣列。該數組的每個元素都指向一個動態分配的子數組,其中每個子數組都有自己不同的長度。
例如:
<code class="c">int *jagged[5]; // Assign memory to each subarray jagged[0] = malloc(sizeof(int) * 10); jagged[1] = malloc(sizeof(int) * 3); // Accessing elements *jagged[0] = 0; *(jagged[0] + 1) = 1; *jagged[1] = 1; *(jagged[1] + 1) = 2; *(jagged[1] + 2) = 3; // Free memory after use free(jagged[0]); free(jagged[1]);</code>
此方法允許創建具有以下行的數組不同的大小,模擬鋸齒狀數組的行為。需要注意的是,每個子數組的記憶體必須動態分配並手動釋放,以避免記憶體洩漏。
以上是我們如何在 C/C 中實現鋸齒狀數組?的詳細內容。更多資訊請關注PHP中文網其他相關文章!