求大佬解答,为何主函数执行到循环好像断了

#include<stdio.h>
#include<malloc.h>
typedef int datatype;
typedef  struct qnode
{
    datatype data;
    struct qnode *next;
}LQNode;
typedef struct
{
    LQNode *rear;
}LQueue;
void Initiate(LQueue *Q)
{
    Q->rear=(LQNode *)malloc(sizeof(LQNode));
    Q->rear=Q->rear->next;
}
int Append(LQueue *Q,datatype x)
{
        LQNode *p;
        p=(LQNode *)malloc(sizeof(LQNode));
        p->data=x;
        p->next=Q->rear->next;
        Q->rear->next=p;
        Q->rear=p;
        return 1;
}
int Delete(LQueue *Q,datatype *d)
{
    LQNode *p;
    if(Q->rear=Q->rear->next)
    {
        printf("队列已空!\n");
    }
    else
    {
        p=(LQNode *)malloc(sizeof(LQNode));
        p=Q->rear->next->next;
        *d=p->data;
    }
    if(p=Q->rear)
    {
        Q->rear=Q->rear->next;
        Q->rear->next=p->next;
    }
    else
        Q->rear->next->next=p->next;
    free(p);
}
int main()
{
    LQueue Q;
    datatype x;
    int i;
    Initiate(&Q);
    printf("输入元素:");
    for(i=0;i<10;i++)
    {
        scanf("%d",&x);
        Append(&Q,x);
        printf("zheli");
    }

    printf("队头元素:%d",Q.rear->next->next->data);
    return 0;
}
 

程序会出现访问地址错误。

void Initiate(LQueue *Q)
{
    Q->rear=(LQNode *)malloc(sizeof(LQNode));
    Q->rear=Q->rear->next;
}

函数里Q里的rear指向了新被分配LQNode类型内存的地址,之后又指向了该地址类型的next成员,但是rear指向的地址是不可访问的,next还没有被初始化,当然rear只是指向了一个不可访问的地址,是没有问题的。

在之后,执行Append(&Q,x);会出现问题

int Append(LQueue *Q,datatype x)
{
        LQNode *p;
        p=(LQNode *)malloc(sizeof(LQNode));
        p->data=x;
        p->next=Q->rear->next;   //这里Q->rear是指向不可访问的地址,是不能访问next的
        Q->rear->next=p;
        Q->rear=p;
        return 1;
}

主函数在最下面,求大佬解答