new二维数组与行数组指针

p[row][col]

int main(int argc, char* argv[])
{
    int row,col,k=1;
    cout<<"Please input row and col:"<<endl;//
    cin>>row>>col;

    //分配空间
    int **p=new int*[row];  //
    for (int i=0;i<row;i++)
    {
        p[i]=new int[col];
    }//空间分配完毕

    for (int m=0;m<row;m++)
    {
        for (int n=0;n<col;n++)
        {
            p[m][n]=k++;
            cout<<setw(4)<<p[m][n]<<" ";
        }
        cout<<endl;
    }
   
    //释放空间
    for (int j=0;j<row;j++)
        delete []p[j];
    delete []p;
    p=0;

    return 0;

}

先建立一个指针数组,再用一个for循环开辟对应的指针数组。

 

 

行数组指针
在上面的说明中我们已经知道,二维数组名是指向行的,它不能对如下说明的指针变量p 直接赋值:
                                int a[3][4]={{10,11,12,13},{20,21,22,23},{30,31,32,33}},*p;
其原因就是p 与a 的对象性质不同,或者说二者不是同一级指针。C 语言可以通过定义行数组指针的方法,使得一个指针变量与二维数组名具有相同的性质。

行数组指针的定义方法如下:
               数据类型 (*指针变量名)[二维数组列数];
例如,对上述a 数组,行数组指针定义如下:
        int (*p)[4];
它表示,数组*p 有4 个int 型元素,分别为(*p)[0]、(*p)[1]、(*p)[2]、(*p)[3] ,亦即p 指向的是有4 个int 型元素的一维数组,
即p 为行指针,

如图6 所示。
p->   (*p)[0]   (*p)[1]   (*p)[2]   (*p)[3]
图6 行指针p 的指向.


此时,可用如下方式对指针p 赋值:
p=a;
赋值后p 的指向如图7 所示。
p        ->   10 11 12 13
p+1   ->    20 21 22 23
p+2   ->    30 31 32 33
图7 所示指针p 在二维数组中的指向

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值