【发布时间】:2021-02-19 11:56:05
【问题描述】:
这是我从 codesdope.com 获得的代码,我稍作修改以了解带有链表的队列 ADT 的工作原理。
但是,我在此代码上使用指针时卡住了。 我只是试图打印出队列中的所有元素,试图改变参数。 而且我无法从队列中转到下一个节点,我是否尝试了这段代码不可能的事情? 因为它是这样设计的还是这里有任何解决方案?
我需要你的帮助或提示如何使用正确的指针跟随指针。
'''
#include <stdio.h>
#include <stdlib.h>
#define TRUE 1
#define FALSE 0
#define FULL 10
typedef struct node{
int data;
struct node *next;
} NodeT;
typedef struct QueueRep{
int length;
NodeT *head;
NodeT *tail;
} QueueRep;
typedef struct QueueRep *queue;
void initialize(queue q){
q->length = 0;
q->head = NULL;
q->tail = NULL;
}
int isempty(queue q) {
return(q->tail == NULL);
}
void enqueue(QueueRep *q, int value) {
if(q->length < FULL) {
NodeT *tmp;
tmp = malloc(sizeof(NodeT));
tmp->data = value;
tmp->next = NULL;
if(!isempty(q)) {
q->tail->next = tmp;
q->tail = tmp;
} else {
q->head = q->tail = tmp;
}
q->length++;
} else {
printf("List is full\n");
}
}
int dequeue(QueueRep *q) {
NodeT *tmp;
int n = q->head->data;
tmp = q->head;
q->head = q->head->next;
q->length--;
free(tmp);
return(n);
}
/* original display function
void display(NodeT *head)
{
if(head == NULL)
{
printf("NULL\n");
}
else
{
printf("%d\n", head -> data);
display(head->next);
}
}
*/
/* I would like to print like this !!!! */
void display(queue q) {
NodeT *p = q->head;
if(p->data == NULL) {
printf("NULL\n");
} else {
printf("%d ", p->data);
display(q->head); //wrong pointer? how can your fix here?
}
}
int main() {
QueueRep *q;
q = malloc(sizeof(QueueRep));
initialize(q);
enqueue(q,10);
enqueue(q,20);
enqueue(q,30);
printf("Queue before dequeue\n");
//display(q->head);
display(q); //this is What I am trying to use
dequeue(q);
printf("\nQueue after dequeue\n");
//display(q->head);
display(q); //this is What I am trying to use
return 0;
}
'''
【问题讨论】:
-
这只是一个糟糕的代码。有什么问题?
-
数据成员不是指针。所以这个 if 语句 if(p->data == NULL) { 没有意义。
-
在这个递归调用中显示(q->head);参数的类型与函数参数的类型不同。
标签: c pointers recursion queue function-definition