我正在阅读编程访谈曝光书。有一个代码用于在链接列表的前面插入一个元素。
bool insertInFront( IntElement **head, int data ){
IntElement *newElem = new IntElement;
if( !newElem ) return false;
newElem->data = data;
*head = newElem;
return true;
}
恕我直言这段代码忘记更新新元素的下一个指针,不是吗?虽然我确信代码是错误的,但我只是想确认我的链表概念并非严重错误。
我相信代码应该在正确的位置添加以下行。
newElem->next = *head;
有人可以告诉我,我是对还是错?
答案 0 :(得分:5)
由于这是插在前面,你是对的。新节点的下一个应该是当前的头部,然后应该将头部设置为指向新节点。
bool insertInFront( IntElement **head, int data ){
IntElement *newElem = new IntElement;
if( !newElem ) return false;
newElem->data = data;
newElem->next = *head;
*head = newElem;
return true;
}
当然,这里还有其他一些不好的风格和设计,或者说是错误的。
答案 1 :(得分:4)
我不确定你正在阅读什么样的面试书,但这个代码示例是可怕的c ++。
是的,在覆盖newElem->next
之前,您需要将head
指向旧版head
。此外,没有理由检查newElem是否为NULL - 如果无法分配,C ++会抛出异常。此外,insertInFront
应该是IntElement
的成员函数,而head
应该是数据成员。