2 a346377452 a346377452 于 2016.02.24 22:33 提问

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

#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);

}
初学写的有点乱

2个回答

caozhy
caozhy   Ds   Rxr 2016.02.24 22:46
已采纳

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

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

WinsenJiansbomber
WinsenJiansbomber   2016.03.06 23:37

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

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!