关于静态链表的动态分配函数

各位大佬,这是我在静态链表程序里写的模拟malloc程序

int Malloc(int Long)//动态分配空间函数
{int num=1;
while(((Stalistpool[num]).real==1)&&(num<=maxsize+1))//当该处的结构体未被调用,且位置在最大范围限制之内
num++;
Stalistpool[num].real=1;
if(num!=maxsize+2)

return num;
else
printf("分配内存失败");
return 0;

}

结构体的定义是

typedef struct list
{
Date key;
couser next;
int real;//是否被引用的判定
}Stalist;
Stalist Stalistpool[maxsize+1]={0,0,0};//储存池 

我把Stalistpool【0】作为保留位,从Stalistpool【1】开始分配空间,按照程序,第一次分配的时候,num输出时应该等于1,但是实际上是等于2,那么Stalistpool【1】去哪里了呢?

不知道你这个问题是否已经解决, 如果还没有解决的话:

如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 以帮助更多的人 ^-^