链队列不对 不知道错在哪里

#include
#include
typedef struct Node {
int number;
char name[20];
Node *next;
}Qnode;
typedef struct {
Qnode *front;
Qnode *rear;
}LinkQueue;
void Enqueue(LinkQueue *q){
int n;
scanf_s("%d", &n);
for (int i = 1;i <= n;i++) {
Qnode p;
scanf_s("%d %s", &p.number, p.name, 20);
if (q->front== q->rear) {
q->front = &p;
q->rear = q->front->next=NULL;

    }
    else {
        q->rear = &p;
        q->rear = q->rear->next=NULL;
    }
}

}
void Dequeue(LinkQueue q) {
//if (q->front == q->rear) printf("empty");
printf("%d %s\n", q->front->number, q->front->name);
q->front = q->front->next;
}
int main() {
LinkQueue *q;
q = (LinkQueue
)malloc(sizeof(LinkQueue));
q->front = q->rear = NULL;
q->front=q->rear= (Qnode*)malloc(sizeof(Qnode));
q->front->next = q->rear->next = NULL;
Enqueue(q);
Dequeue(q);

}
初学写的有点乱

Qnode p;
这个肯定不行,必须用malloc动态分配,否则每次都使用同一个存储。

参考
http://blog.csdn.net/zhangfei0554/article/details/4809156

发现提问都都不懂如何添加代码,搞这么乱的贴上来很考眼神诶