C/C++ 動態(tài)數(shù)組的創(chuàng)建的實例詳解
C/C++ 動態(tài)數(shù)組的創(chuàng)建的實例詳解
在C++語言中,二維動態(tài)數(shù)組主要使用指針的方法建立,以建立一個整數(shù)二維數(shù)組為例:
#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<<"輸入二維數(shù)組的行數(shù)和列數(shù)"<<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<<"輸入二維數(shù)組"<<endl;
for(int j=0 ; j !=row ; j++)
{for(int k=0 ; k !=column ; k++) {cin>>array[j][k]; } }
cout<<"輸入的二維數(shù)組為"<<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;
}
動態(tài)創(chuàng)建一維數(shù)組
int len;
cout<<"輸入一維數(shù)組大小:"<<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<<"輸出一維數(shù)組:"<<endl;
for(i=0;i!=len;i++)
{
cout<<p[i]<<" ";
}
cout<<endl;
動態(tài)分配二維數(shù)組
int main(int argc,char **argv)
{
int column,row;
cout<<"輸入二維數(shù)組的行數(shù)和列數(shù)"<<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<<"輸入二維數(shù)組"<<endl;
for(int j=0 ; j !=row ; j++)
{for(int k=0 ; k !=column ; k++) {cin>>array[j][k]; } }
cout<<"輸入的二維數(shù)組為"<<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++中在結(jié)構(gòu)體里面動態(tài)創(chuàng)建數(shù)組,而且創(chuàng)建動態(tài)結(jié)構(gòu)體數(shù)組
大家看一下這個例子就知道了!
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;
}
總的思想是,先生成結(jié)構(gòu)體數(shù)組,再在每個元素里面聲明動態(tài)數(shù)組!
就是先實例化,再在實例化的元素里面聲明動態(tài)數(shù)組!
可以通過在里面填入東西,進(jìn)行測試一下!
如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
全面了解#pragma once與 #ifndef的區(qū)別
下面小編就為大家?guī)硪黄媪私?pragma once與 #ifndef的區(qū)別。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-08-08
C++利用std::forward_list查找插入數(shù)據(jù)方法示例
這篇文章主要給大家介紹了關(guān)于C++利用std::forward_list查找插入數(shù)據(jù)的相關(guān)資料,文中先對std::forward_list進(jìn)行了詳細(xì)的介紹,而后通過示例代碼給大家介紹了查找的方法,需要的朋友可以參考借鑒,下面話不多說了,來一起看看吧。2017-08-08

