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-08C++利用std::forward_list查找插入數(shù)據(jù)方法示例
這篇文章主要給大家介紹了關(guān)于C++利用std::forward_list查找插入數(shù)據(jù)的相關(guān)資料,文中先對std::forward_list進(jìn)行了詳細(xì)的介紹,而后通過示例代碼給大家介紹了查找的方法,需要的朋友可以參考借鑒,下面話不多說了,來一起看看吧。2017-08-08