吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 855|回复: 4
收起左侧

[讨论] 两两交换链表节点,为什么不能用head

[复制链接]
djdgf4 发表于 2023-8-2 21:12
这是我通过的代码,但是我之前18是

while(head != nullptr && (head->next) != nullptr)


然后报了错误:

Line 21: Char 35: runtime error: member access within null pointer of type 'ListNode' (solution.cpp)
SUMMARY: UndefinedBehaviorSanitizer: undefined-behavior prog_joined.cpp:30:35


这是为什么?

[C++] 纯文本查看 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* swapPairs(ListNode* head) {
        ListNode* _HEAD = new ListNode(0);//虚拟头节点
        ListNode* fast = nullptr,*last = nullptr;
        _HEAD->next = head;
        last = _HEAD;
        while(last->next != nullptr && (last->next->next) != nullptr)
        {
            fast = last->next;
            ListNode* tmp = fast->next;
            last->next = tmp;
            fast->next = tmp->next;
            tmp->next = fast;

            last = last->next->next;

        }
        return _HEAD->next;
    }
};

while(head != nullptr && (head->next) != nullptr)

免费评分

参与人数 3吾爱币 +2 热心值 +3 收起 理由
Quasi + 1 用心讨论,共获提升!
wsdxdc1 + 1 + 1 热心回复!
为之奈何? + 1 + 1 我很赞同!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

熊猫拍板砖 发表于 2023-8-2 23:38
可以使用head

/* Definition for singly-linked list. type ListNode struct {     Val int     Next ListNode } /
func swapPairs(head ListNode) ListNode {  
   if head == nil || head.Next == nil{        return head    }  
dummy:=&ListNode{Next:head}  
prev:=dummy  
for head!=nil && head.Next!=nil{      
// 把第二个结点摘取出来      
next:=head.Next      
// 先让第一个结点Next指向第三个结点      
head.Next=next.Next      
// 然后第二个结点和第三个结点断开关系      
next.Next=head      
// prev 指向临时结点      
prev.Next=next      
// 结点交换        
prev = head      
head=head.Next    }  
return dummy.Next}

头像被屏蔽
86618513 发表于 2023-8-3 07:58
hdydy 发表于 2023-8-3 10:24
本帖最后由 hdydy 于 2023-8-3 10:29 编辑

[C++] 纯文本查看 复制代码
class Solution {
public:
    ListNode* swapPairs(ListNode* head) {
        ListNode* _HEAD = new ListNode(0, head);// 虚拟头节点
        ListNode* p = _HEAD, *q = nullptr;// p->head->q,交换head和q之后,p后移2步
        while(head && head->next) {
            q = head->next;
            head->next = q->next;
            q->next = head;
            p->next = q;
            p = head;
            head = p->next;
        }
        return _HEAD->next;
    }
};
laoyehuamao 发表于 2023-8-3 11:30
太深奥了!!!
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2025-1-11 00:54

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表