我试图在连续的内存块中创建2D数组,但是它给出了M个连续块,每个都是N个大小.
int **arr = new int*[M];
for (int i = 0 ; i < M ; i++ )
{
arr[i] = new int[N];
}
Run Code Online (Sandbox Code Playgroud)
如何在连续内存块中创建2D数组?
max*_*000 13
int *buffer=new int[M*N];
int **arr=new int*[M];
for(int i=0;i<M;++i)
arr[i]=buffer+i*N;
Run Code Online (Sandbox Code Playgroud)
实际上没有必要存储arr指针 - 可以在需要时计算它们.
| 归档时间: |
|
| 查看次数: |
2938 次 |
| 最近记录: |