题解 | #牛牛的链表删除#

牛牛的链表删除

https://www.nowcoder.com/practice/d3df844baa8a4c139e103ca1b1faae0f

#include <iostream>
using namespace std;
struct Node
{
    int val;
    Node* next;
    Node(): val(0), next(nullptr) {}
    Node(int val): val(val), next(nullptr) {}
    Node(int val, Node* next): val(val), next(next) {}
};

void createList(Node* dummy, int n)
{
    int i = 0;
    Node* node = dummy;
    while (i != n)
    {
        int d;
        cin >> d;
        node->next = new Node(d);
        node = node->next;
        i++;
    }
}

void deleteListNode(Node* dummy, int x)
{
    Node* node = dummy;
    while (node->next != nullptr)
    {
        if (node->next->val == x)
        {
            Node* temp = node->next;
            node->next = node->next->next;
            delete temp;
        }
        node = node->next;
    }
}

void printList(Node* dummy)
{
    Node* node = dummy->next;
    while (node != nullptr)
    {
        cout << node->val << " ";
        node = node->next;
    }
}

int main() {
    int n, x;
    cin >> n >> x;
    Node* dummy = new Node();
    createList(dummy, n);
    deleteListNode(dummy, x);
    printList(dummy);

    return 0;


}
// 64 位输出请用 printf("%lld")

全部评论

相关推荐

黎明azzz:刘女士吓坏了
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务