以下是在堆上創建2D數組(或動態分配2D數組)的不同方法。
在以下示例中,我們將「 r 」視為行數,將「 c 」視為列數,並創建了一個二維數組,其中r = 3,c = 4,並遵循以下值
1 2 3 4 5 6 7 8 9 10 11 12
1.使用單個指針:
一種簡單的方法是使用簡單的指針算法分配大小為r * c的存儲塊和訪問元素。
#include <stdio.h> #include <stdlib.h> int main() { int r = 3, c = 4; int *arr = (int *)malloc(r * c * sizeof(int)); int i, j, count = 0; for (i = 0; i < r; i++) for (j = 0; j < c; j++) *(arr + i*c + j) = ++count; for (i = 0; i < r; i++) for (j = 0; j < c; j++) printf("%d ", *(arr + i*c + j)); return 0; }
2.使用指針數組
我們可以創建大小為r的指針數組。請注意,從C99開始,C語言允許使用可變大小的數組。創建指針數組後,我們可以為每行動態分配內存。
#include <stdio.h> #include <stdlib.h> int main() { int r = 3, c = 4, i, j, count; int *arr[r]; for (i=0; i<r; i++) arr[i] = (int *)malloc(c * sizeof(int)); count = 0; for (i = 0; i < r; i++) for (j = 0; j < c; j++) arr[i][j] = ++count; // Or *(*(arr+i)+j) = ++count for (i = 0; i < r; i++) for (j = 0; j < c; j++) printf("%d ", arr[i][j]); return 0; }
3.使用指向指針的指針
我們還可以使用雙指針動態創建指針數組。一旦我們動態分配了數組指針,就可以像方法2一樣為每行動態分配內存。
#include <stdio.h> #include <stdlib.h> int main() { int r = 3, c = 4, i, j, count; int **arr = (int **)malloc(r * sizeof(int *)); for (i=0; i<r; i++) arr[i] = (int *)malloc(c * sizeof(int)); count = 0; for (i = 0; i < r; i++) for (j = 0; j < c; j++) arr[i][j] = ++count; for (i = 0; i < r; i++) for (j = 0; j < c; j++) printf("%d ", arr[i][j]); return 0; }
4.使用雙指針和一個malloc調用
#include<stdio.h> #include<stdlib.h> int main() { int r=3, c=4, len=0; int *ptr, **arr; int count = 0,i,j; len = sizeof(int *) * r + sizeof(int) * c * r; arr = (int **)malloc(len); ptr = (int *)(arr + r); for(i = 0; i < r; i++) arr[i] = (ptr + c * i); for (i = 0; i < r; i++) for (j = 0; j < c; j++) arr[i][j] = ++count; for (i = 0; i < r; i++) for (j = 0; j < c; j++) printf("%d ", arr[i][j]); return 0; }
領取免費學習資料以及教程請點擊下方了解更多按鈕: