数据结构中如何用c语言给数据元素赋值?

#include<stdio.h>
#include<stdlib.h>

#define MAXSIZE 100
#define OK 1
#define ERROR 0
#define status int

typedef struct
{
    float codf;
    int expn;
 } book;
 typedef struct
 {
     book *elem;
     int length;
 }sqlist;
 
 status Initlist(sqlist *l) 
 {
     l->elem=(book *)malloc(MAXSIZE * sizeof(book));
     if(!l->elem) exit (ERROR);
     l->elem=0;
     return OK;
 }
 status listinsert(sqlist*l,book e)
{
           int i=0;    
            l->elem[i] = e;//在这一行被卡主了,程序停止运行
               printf("ok");
        l->length++;
        i++;
        return OK;
}
 int main()
 {    
     sqlist l;
     if(Initlist(&l)) 
     printf("ok");
     book e;
     e.codf=2;
     e.expn=1;
     if(listinsert(&l,e))
     printf("ok");    
 }

输出结果是一个OK,之前试过了,应该是在上面标准的那里卡住了,无法把e赋值给l->elem[i],请问这是为什么,怎样解决?

l->elem = 0;相当于l->elem = NULL;
这一句把分配内存的操作给抹掉了。

#include<stdio.h>
#include<stdlib.h>
#define MAXSIZE 100
#define OK 1
#define ERROR 0
#define status int
typedef struct
{
    float codf;
    int expn;
 } book;
 typedef struct
 {
     book *elem;
     int length;
 }sqlist;
 status Initlist(sqlist *l) 
 {
     l->elem=(book *)malloc(MAXSIZE * sizeof(book));
     if(!l->elem) 
        exit (ERROR);
     l->length = 0;
     return OK;
 }
 status listinsert(sqlist*l,book e)
{ 
            l->elem[length]->codf = e.codf;//在这一行被卡主了,程序停止运行
            l->elem[length]->expn = e.expn;
               printf("ok");
        l->length++;
        return OK;
}
 int main()
 {    
     sqlist l;
     if(Initlist(&l)) 
     printf("ok");
     book e;
     e.codf=2;
     e.expn=1;
     if(listinsert(&l,e))
     printf("ok");    
 }