如何在C++中创建一维动态数组?

 我来答
丶骑着牛看美女
2018-03-31 · TA获得超过2234个赞
知道小有建树答主
回答量:12
采纳率:0%
帮助的人:6190
展开全部

在C++语言中,二维动态数组主要使用指针的方法建立,以建立一个整数二维数组为例:

?

123456789101112131415161718192021222324252627282930313233

#include<iostream>#include<string>#include<malloc.h>using namespace std;int main(int argc,char **argv){ ///*int a[2][3]={{1,2,3},{4,5,6}}; //cout<<sizeof(a+1)<<endl;*/ //int a=4; //int **pp; //pp=(int **)malloc(sizeof(int*)*a); //int aa[5][1]={1,2,3,4,5}; //return 0;int column,row; cout<<"输入二维数组的行数和列数"<<endl;cin>>row>>column;int **array;array = (int **)malloc(sizeof(int *)*row);for(int i=0;i!=row ; i++) array[i]=(int *) malloc(sizeof(int )*column);cout<<"输入二维数组"<<endl;for(int j=0 ; j !=row ; j++){for(int k=0 ; k !=column ; k++) {cin>>array[j][k]; } }cout<<"输入的二维数组为"<<endl;for( int j=0 ; j !=row ; j++ ){ for(int k=0 ; k !=column ; k++){cout<<array[j][k]<<" "; }cout<<endl; }//释放空间   for(int i=0 ;i!=row;i++) free(array[i]);free(array);return 0;}

动态创建一维数组

?

123456789101112131415161718

int len; cout<<"输入一维数组大小:"<<endl; cin>>len; int *p=new int[len];   cout<<"输入元素,元素之间以空格分隔!"<<endl; int val,i=0; for(i=0;i!=len;i++) {cin>>val; p[i]=val; } cout<<"输出一维数组:"<<endl; for(i=0;i!=len;i++) {   cout<<p[i]<<" "; } cout<<endl;

动态分配二维数组

?

1234567891011121314151617181920212223242526

int main(int argc,char **argv){ int column,row;cout<<"输入二维数组的行数和列数"<<endl;cin>>row>>column;int **array;//array = (int **)malloc(sizeof(int *)*row);//方法一 array=new int *[row];for(int i=0;i!=row ; i++) //array[i]=(int *) malloc(sizeof(int )*column);//方法一 array[i]=new int [column];cout<<"输入二维数组"<<endl;for(int j=0 ; j !=row ; j++){for(int k=0 ; k !=column ; k++) {cin>>array[j][k]; } }cout<<"输入的二维数组为"<<endl;for( int j=0 ; j !=row ; j++ ){ for(int k=0 ; k !=column ; k++){cout<<array[j][k]<<" "; }cout<<endl; }//释放空间   for(int i=0 ;i!=row;i++) free(array[i]);free(array);return 0;}

C++中在结构体里面动态创建数组,而且创建动态结构体数组

大家看一下这个例子就知道了!

?

123456789101112131415161718192021222324252627282930313233

int main(int argc, char* argv[]){int n,i,m,j;  struct test{  int *array;};test *testarray;cin>>n>>m;testarray=new test[m];for (i=0;i<m;i++){testarray[i].array=new int[n];}for (i=0;i<m;i++){  for (j=0;j<n;j++)  {  testarray[i].array[j]=i+j;  }  }for (i=0;i<m;i++){  for (j=0;j<n;j++)  {  cout<<testarray[i].array[j];     }  cout<<endl;}return 0;}

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式