栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

C&C++动态创建数组

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

C&C++动态创建数组

一维
#include 
using namespace std;

int main(){
    int *pi1 = new int;  //创建int指针
    int *pi2 = new int(2);  //创建int指针并初始化为2
    int *pi3 = new int[3];  //创建3个int指针
    
    delete pi1;
    delete pi2;
    delete [] pi3;
    return 0;
}
#include 
using namespace std;
struct Matrix{
    int width;
    int height;
    float *elements;
}

int main(){
    int w = 4, h = 2;
    Matrix *A;
    A = (Matrix*)malloc(sizeof(Matrix));
    A->width = w;
    A->height = h;
    A->elements = (float*)malloc(A->width * A->height * sizeof(float));
    
    free(A->elements);
    free(A);
    
    // c++
    // Matrix *A = new Matrix;
    // A->height = h;
    // A->width = w;
    // A->elements = new float[A->width * A->height];
    
    // delete [] A->elements;
    // delete A;
    return 0;
}
二维
#include  
#include  
// 二维指针
int main()  
{  
    int **a;  //用二级指针动态申请二维数组  
    int i, j;  
    int m = 4, n = 2;
    a=(int**)malloc(sizeof(int*) * m);  
    for(i = 0; i < m; i++)  
      a[i]=(int*)malloc(sizeof(int) * n);  
    for(i = 0; i < m; i++)  
      for(j = 0; j < n; j++)  
        printf("%pn",&a[i][j]);     //输出每个元素地址,每行的列与列之间的地址时连续的,行与行之间的地址不连续  
    for(i = 0; i < m; i++)  
      free(a[i]);  
    free(a);  
    return 0;  
}
#include  
#include  
// 数组指针
int main()  
{  
    int i,j;  
    int m = 4;
    const int n = 2;
    //申请一个4行2列的整型数组  
    int(*a)[n] = (int(*)[n])malloc(sizeof(int) * m * n); 
    for(i = 0; i < m; i++)  
        for(j = 0; j < n; j++)  
           printf("%pn",&a[i][j]);  //输出数组每个元素地址,每个元素的地址是连续的  
    free(a);  
    return 0;  
}
#include
using namespace std;

int main()
{
    int row = 4, col = 2;
    //为行指针分配空间 
    int **arr = new int *[row];    
    for(int i = 0; i < row; i++)
         arr[i]= new int[col];//为每行分配空间(每行中有col个元素) 
    
    //释放二维数组(反过来) 
    for(int i = 0;i < row;i++)
        delete [] arr[i]; 
    delete [] arr;
    return 0;
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/291217.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号