weixin_43306709 2022-03-19 21:52 采纳率: 77.3%
浏览 11
已结题

leetcode上面,我思路是先把链表反转,然后在把两个链表连起来,然后从中间断开,但为什么最后的不出来结果啊

问题遇到的现象和发生背景

https://leetcode-cn.com/problems/reorder-list/

问题相关代码,请勿粘贴截图
class Solution {
private:
    //反转链表
    ListNode* reverseList(ListNode* head){
        while(head == nullptr||head->next == nullptr)
                return head;
        ListNode* p =reverseList(head->next);
        head->next->next = head;
        head->next = nullptr;
        return p;
    }
    //找到链表中间节点
public:
    void reorderList(ListNode* head) {
        ListNode* newHead = reverseList(head);
        ListNode* temp1 = head;
        ListNode* p1 = temp1->next;
        ListNode* temp2 = newHead;
        ListNode* q1 = temp2->next;
        while(p1){
            temp1->next = temp2;
            temp2->next = p1;
            temp1 = p1;
            temp2 = q1;
            p1 = p1->next;
            q1 = q1->next;
        }
        ListNode* temp = head;
        int length = 0;
        while(temp){
            temp = temp->next;
            length++;
        }
        temp = head;
        for(int i = 0;i<length/2-1;i++){
            temp = temp->next;
        }
        temp->next = nullptr;


    }
};

运行结果及报错内容
我的解答思路和尝试过的方法
我想要达到的结果
  • 写回答

1条回答 默认 最新

  • SmallAntJ 2022-03-20 00:27
    关注

    反转链表的函数 reverseList 直接修改了原链表,而不是新建一个反向的链表,所以原来的链表已经被破坏了。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 4月3日
  • 已采纳回答 3月26日
  • 创建了问题 3月19日

悬赏问题

  • ¥15 各位请问平行检验趋势图这样要怎么调整?说标准差差异太大了
  • ¥15 delphi webbrowser组件网页下拉菜单自动选择问题
  • ¥15 wpf界面一直接收PLC给过来的信号,导致UI界面操作起来会卡顿
  • ¥15 init i2c:2 freq:100000[MAIXPY]: find ov2640[MAIXPY]: find ov sensor是main文件哪里有问题吗
  • ¥15 运动想象脑电信号数据集.vhdr
  • ¥15 三因素重复测量数据R语句编写,不存在交互作用
  • ¥15 微信会员卡等级和折扣规则
  • ¥15 微信公众平台自制会员卡可以通过收款码收款码收款进行自动积分吗
  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab