编程访谈中的错误暴露:链接列表

时间:2010-10-14 02:25:00

标签: c++ list insert linked-list

我正在阅读编程访谈曝光书。有一个代码用于在链接列表的前面插入一个元素。

bool insertInFront( IntElement **head, int data ){
    IntElement *newElem = new IntElement;
    if( !newElem ) return false;
    newElem->data = data;
    *head = newElem;
    return true;
}

恕我直言这段代码忘记更新新元素的下一个指针,不是吗?虽然我确信代码是错误的,但我只是想确认我的链表概念并非严重错误。

我相信代码应该在正确的位置添加以下行。

newElem->next = *head;

有人可以告诉我,我是对还是错?

2 个答案:

答案 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应该是数据成员。