专栏首页架构说题目:将链表的奇数位和偶数位调换组成新的链表

题目:将链表的奇数位和偶数位调换组成新的链表

题目:将链表的奇数位和偶数位调换组成新的链表

原题链接: http://oj.leetcode.com/problems/swap-nodes-in-pairs/

Given a linked list, swap every two adjacent nodes and return its head. For example, Given 1->2->3->4, you should return the list as 2->1->4->3. Your algorithm should use only constant space. You may not modify the values in the list, only nodes itself can be changed

分析

struct ListNode* swapPairs(struct ListNode* head)

Q1 Given 1->2->3->4, you should return the list as 2->1->4->3 head指向第一个元素 1 函数指针传递是传递 无论如何交换参数head 不可能返回指向元素2 如何解决?

  • 必须重新建立一个新的链表 进行返回
  • 采用 带头节点单链表 知识补充:带头节点单链表和不带头节点单链表有什么区别 带头结点单链表好处解决了 不用判断第一个节点是否为空 不需要特殊处理 用统一方法实现就 例如 链表insert操作** 返回值是最新链表 struct ListNode* head 不是

Q2: 链表遍历操作 ptr(A)=ptr->next(B) 前提条件节点A和节点B 位置关系没有发现变化 在链表排序(交换位置是排序一个方法)原来位置发生改变如何处理 ?

  • 需要临时遍历记录 下 B位置
  • 链表交换节点 影响不是2个 而是三个 不要忘记最后 1 -2-3 A=2 B=3 2-1-3 A=2 B=1 >>A=1 B=3 解题思路如下

第一次循环处理结果: root: 0 ->1->2->3 ->4 之前 pre=0 cur=1 root: 0 ->2->1->3->4 之后 pre=1 cur=3 pre相对于原来排序移动2次

code

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *    int val;
 *    ListNode* next;
 *    ListNode(int x): val(x), next(NULL) {}
 * };
 */class Solution {
public:
    ListNode* swapPairs(ListNode* head) 
    {     
          //head节点
          ListNode root(0);
          root.next =head;

          ListNode * pre=&root;//0
          ListNode * cur =head;//1

         while(cur && cur->next)
         {           //swap 
           pre->next=cur->next;// 0 --> 2     
           cur->next=pre->next->next;//1 --> 3
           pre->next->next=cur;//2->1

          pre=cur;// 虽然 pre 仍然指向 位置1 原来位置1 swap之后放到位置2后面
          cur=cur->next;//pre ->1 cur->3 节         //0 ->2->1->3->4         
  }

       return root.next;    
    }
};

执行行效率分析: https://leetcode.com/submissions/detail/102239317/

耗时6ms不是最优解呀 耗时应该在建立头节点 如果不用头节点 需要特殊处理 第一次处理时候null 查看耗时3秒的 提取到函数外面 为了防止异常数据 异常判断

为了完成遍历 采用三个节点 first second three 三个节点

可以采用递归方式

参照历史题目:

题目:判断一个单链表是否回文链表

本文分享自微信公众号 - 架构说(JiaGouS),作者:单链表

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2017-05-08

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 每日一题2-对链表进行插入排序

    输入: 4->2->1->3 输出: 1->2->3->4 示例 2: 输入: -1->5->3->4->0 输出: -1->0->3->4->5

    程序员小王
  • How Redis replication works?

    这个是在oneNote上笔记,拷贝出来是一个图片 ?

    程序员小王
  • 漫谈递归-链表合并

    将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。

    程序员小王
  • 【Leetcode】82. 删除排序链表中的重复元素 II

    给定一个排序链表,删除所有含有重复数字的节点,只保留原始链表中 没有重复出现 的数字。

    Leetcode名企之路
  • 【leetcode刷题】T103-从分类列表中删除重复项目 II

    使用两个指针pre和cur,pre始终指向链表前一部分非重复元素的最后一个节点,cur指向pre指向的节点后重复元素的最后一个节点。当pre->next == ...

    木又AI帮
  • LeetCode-24 两两交换链表中的节点

    今天我们学习第24题两两交换链表中的节点,这是一道中等题。像这样链表的题目经常作为面试题来考察面试者算法能力和写代码能力,因此最好能手写出该题。下面我们...

    用户3470542
  • leetcode 19 Remove Nth Node From End of List

    @坤的
  • NDK--Android Studio中配置FFmpeg动态链接库

    aruba
  • LinkedList - 23. Merge k Sorted Lists

    Merge k sorted linked lists and return it as one sorted list. Analyze and descri...

    用户5705150
  • Swap Nodes in Pairs

    问题:交换相邻的两个结点 分析:建立新链表每次插入ret->next后在插入ret,需要在判断下若最后只有一个结点不需要交换,注意每次交换了结点要把尾结点的下一...

    用户1624346

扫码关注云+社区

领取腾讯云代金券