我从前对C++链表不太熟悉,现在看书上有一个例子讲链表的创建和遍历:
struct ListNode
{
int content;
ListNode *next;
}; // 请问:这里写或者不写“ListNode *head=NULL;”有什么区别?
void List_Create(ListNode *&LN, int array[], int n)
{
ListNode* p;
int i;
LN = (ListNode*)malloc(sizeof(ListNode)); // 请问:这里的LN为什么要用malloc分配内存呢?直接ListNode* LN为什么不行呢?
LN->next = NULL; // 把LN作为结尾指向NULL.
for(i=n-1; i>=0; i--)
{
p = (ListNode*)malloc(sizeof(ListNode)); // 请问:这里的p为什么要用malloc分配内存呢?直接ListNode* p为什么不行呢?
p->content = array[i];
p->next = LN->next; // 直接写p->next = LN为什么不对呢?
LN->next = p; // 请问:为什么前面是把LN-next赋给p-next、这里却把p整个赋给了LN呢?
}
}
void List_Display(ListNode *&LN)
{
cout << "\nThe displayed list is: " << endl;
while(LN -> next != NULL)
{
cout << LN->next->content << " ";
LN = LN->next;
}
cout << endl;
}
请教一下大家4个问题:
1 最开始的struct那一段,结尾处写或者不写 ListNode *head=NULL有什么区别?
2 Create函数中,LN=(ListNode*)malloc(sizeof(ListNode)) 以及 p=(ListNode*)malloc(sizeof(ListNode)); 请问:这里的LN为什么要用malloc分配内存呢?直接ListNode* LN和ListNode* p为什么不行呢?最开始struct那里 ListNode*head定义的时候也没malloc分配内存啊?
3 Create函数中,p->next = LN->next; LN->next = p;这应该是实现p的插入。但是为什么前面是把LN-next赋给p-next、后面却把p整个赋给了LN-next呢? 如果写 p->next = LN; LN->next = p; 这样看起来更一致,为什么不对呢?
4 Display函数虽然遍历了整个链表,但是也事实上移动到了链表的末端。有没有什么办法能既遍历、又不移动到末端呢?
谢谢了先!