一维和二维数组 动态内存分配
一维数组的动态内存分配
#include "stdafx.h" #include <iostream> using namespace std; int main() { int length,i; int *p; cin>>length; p=new int[length]; for(i=0;i<length;i++) { p[i]=i; //不要写成*p[i]=i; cout<<p[i]<<endl; //不要写成cout<<*p[i]<<endl; } delete []p; p=0; return 0; }
2、利用指针的指针实现二维数组的动态存储
int **p; ..... p = new int*[n]; //申请行空间 for (i=0;i<n;i++) { p[i]=new int [n]; //申请列空间 }
3、动态分配内存的指针数组
#include "stdafx.h" #include <iostream> using namespace std; int main() { int (*p)[2]=new int[2][2]; int i,j; int a[2][2]={1,2,3,4}; for (i=0;i<2;i++) for (j=0;j<2;j++) { p[i][j]=a[i][j]; } //p=a; cout<<"p[0][0]的地址为:"<<p[0]<<endl<<endl; for (i=0;i<2;i++) { for (j=0;j<2;j++) cout<<p[i][j]<<"\t"; cout<<endl; } delete[] p; p=0; return 0; }
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。