動態記憶體空間的申請示範

來源:果殼範文吧 1.01W

利用C++的'特性,能夠自定義空間的型別大小和空間長度

動態記憶體空間的申請示範

下面這個程式是個陣列動態配置的簡單示例

複製程式碼 程式碼如下:

#include

using namespace std;

int main()

{ int size = 0;

cout << "請輸入陣列長度:"; //能夠自定義的動態申請空間長度

cin >> size;

int *arr_Point = new int[size];

cout << "指定元素值:" << endl;

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

{ cout << "arr[" << i << "] = ";

cin >> *(arr_Point+i);

}

cout << "顯示元素值:" << endl;

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

{ cout << "arr[" << i << "] = " << *(arr_Point+i)

<< endl;

}

[] arr_Point;

return 0;

}

執行結果:

複製程式碼 程式碼如下:

請輸入陣列長度:5

指定元素值:

arr[0] = 1

arr[1] = 2

arr[2] = 3

arr[3] = 4

arr[4] = 5

顯示元素值:

arr[0] = 1

arr[1] = 2

arr[2] = 3

arr[3] = 4

arr[4] = 5

可以使用指標來模擬二維陣列,只要清楚二維陣列中的兩個維度的索引值之位移量就可以

複製程式碼 程式碼如下:

#include

using namespace std;

int main()

{ int m = 0;

int n = 0;

cout << "輸入二維陣列維度:";

cin >> m >> n;

int *ptr = new int[m*n];

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

{ for(int j = 0; j < n; j++)

{ *(ptr + n*i + j) = i+j;

}

}

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

{ for(int j = 0; j < n; j++)

{ cout << *(ptr+n*i+j) << "t";

}

cout << endl;

}

[] ptr;

return 0;

}

熱門標籤