返回指向排序列表的指针; C ++中的链表

时间:2015-02-01 23:36:49

标签: c++ string linked-list

我希望这个函数sortPair获取2个Node指针并返回一个指向按字母顺序排序的2个元素列表的指针。下面的代码是我到目前为止的代码。如果有人能让我知道我哪里出错了,那就太棒了。

  struct Node{
        string val;
        Node* next;
    };

Node* sortPair (Node* p1, Node* p2){
    //Assert that neither pointer is null
    assert(p1!=NULL);
    assert(p2!=NULL);

    Node* head=NULL;
    Node* current=NULL;
    Node* last = NULL;

    current = new Node();
    if(p1-> val >p2-> val)   //If p1->val comes before p2->val in the alphabet
    {
        current->val = p1->val;
        head = current;
        last = current;
        current = new Node();
        current -> val = p2->val;
        last = current;
        last ->next = NULL;
    }
    else
    {
        current->val = p2->val;
        head = current;
        last = current;
        current = new Node();
        current -> val = p1->val;
        last = current;
        last ->next = NULL;
    }
        return head;
}

1 个答案:

答案 0 :(得分:0)

链表只是一系列节点,每个节点都链接到指向下一个元素的指针。

从您的代码中,您似乎不想列出两个节点,而是将节点插入已存在的列表中。

如果您要做的只是创建那里的两个节点的链接列表,那么根据您对它们的排序方式设置具有更低或更高值的链接列表,指向另一个节点。例如,如果要从最小到最大排序,请将最小节点的下一个指针设置为指向较大的节点并返回最小节点的指针。

如果要将其中一个节点添加到节点列表中,则必须循环遍历列表,直到找到大于或小于要插入的节点的节点。我建议使用while循环。

如果要合并两个列表,则必须创建一个新循环,将一个列表的每个元素插入到另一个列表中。

无需为此任何一个创建新节点,只需使用您拥有的节点并更改下一个指针。

希望这有帮助。