前言:本人在学习数据结构的过程中,遇到了散列这种数据结构,在使用分离链表发构建散列的过程中,需要用到为指针的指针动态分配内存空间,所以本人写了一个C语言的Demo程序来先测试这一行为
问题如图
#include "stdafx.h"
//输出数组测试
void PrinT(int *p,int size){
for (size_t i = 0; i < size; i++)
{
printf("%d ", p[i]);
}
printf("\n");
}
int _tmain(int argc, _TCHAR* argv[])
{
int **p;
int GroupSize = 5;//外层size
int innerSize = 2;//内层size
//申请由外到内
p = (int**)malloc(sizeof(int*)*GroupSize);
for (size_t i = 0; i < GroupSize; i++)
{
//p[i]是一个innerSize大小的int数组的首地址
p[i] = (int*)malloc(sizeof(int)*innerSize);
for (size_t j = 0; j < innerSize; j++)
{
p[i][j] = i+j;
}
PrinT(p[i], innerSize);
}
//释放从内到外
for (size_t i = 0; i < innerSize; i++)
{
free(p[i]);
}
free(p);
return 0;
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34