博客
关于我
两两交换链表中的节点
阅读量:170 次
发布时间:2019-02-28

本文共 1298 字,大约阅读时间需要 4 分钟。

在这里插入图片描述

在这里插入图片描述

递归解法

class Solution {   public:    ListNode* swapPairs(ListNode* head)     {           //在递归到最后两个节点的时候,返回head==NULL,相当于把倒数第二个节点next赋值为NULL        //就是把倒数第一个节点和倒数第二个节点进行交换        if (head == NULL || head->next == NULL)        {               return head;        }        //函数返回的是要交换两个节点的后面一个节点,相当于将交换后的两个节点在放入原链表中        ListNode* newlist = swapPairs(head->next->next);        //下面是进行两个节点交换的代码        ListNode* p = head->next;        //把原先后一个节点next指向它的前一个节点        p->next = head;        //前一个节点head指向的节点,接收newlsit的值        head->next = newlist;//原先p节点在head节点之后,此时head与p的位置互换了        //返回p节点,因为此时p排在head前面,原先指向head的节点,此时应该指向p        return p;    }};

在这里插入图片描述

非递归解法

class Solution {   public:    ListNode* swapPairs(ListNode* head)     {           ListNode* dummyNode = new ListNode(0);          dummyNode->next= head;//虚节点(指向第一个有数据节点的头结点)        ListNode* temp = dummyNode;//用来遍历链表        while (temp->next != NULL && temp->next->next != NULL)//当还剩一个或没有节点的时候,停止交换        {               //每一次将temp后面两个节点进行交换操作            ListNode* node1 = temp->next;            ListNode* node2 = temp->next->next;            //交换            node1->next = node2->next;            node2->next = node1;            temp->next = node2;            //更新temp位置            temp = node1;        }        return dummyNode->next;    }};

转载地址:http://izzc.baihongyu.com/

你可能感兴趣的文章
Mysql学习总结(53)——使用MySql开发的Java开发者规范
查看>>
Mysql学习总结(54)——MySQL 集群常用的几种高可用架构方案
查看>>
Mysql学习总结(55)——MySQL 语句大全再温习
查看>>
Mysql学习总结(56)——MySQL用户管理和权限设置
查看>>
Mysql学习总结(57)——MySQL查询当天、本周、本月、上周、本周、上月、距离当前现在6个月数据
查看>>
Mysql学习总结(58)——深入理解Mysql的四种隔离级别
查看>>
Mysql学习总结(59)——数据库分库分表策略总结
查看>>
Mysql学习总结(5)——MySql常用函数大全讲解
查看>>
Mysql学习总结(60)——并发量大、数据量大的互联网业务数据库设计规范总结
查看>>
Mysql学习总结(61)——MySQL优化之DBA级优化整理汇总
查看>>
Mysql学习总结(62)——MySQL连接com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link问题
查看>>
Mysql学习总结(63)——Mysql数据库架构方案选择与分析
查看>>
Mysql学习总结(64)——Mysql配置文件my.cnf各项参数解读
查看>>
Mysql学习总结(65)——项目实战中常用SQL实践总结
查看>>
Mysql学习总结(66)——设置MYSQL数据库编码为UTF-8
查看>>
Mysql学习总结(67)——MYSQL慢查询日志
查看>>
Mysql学习总结(68)——MYSQL统计每天、每周、每月、每年数据 SQL 总结
查看>>
Mysql学习总结(69)——Mysql EXPLAIN 命令使用总结
查看>>
Mysql学习总结(6)——MySql之ALTER命令用法详细解读
查看>>
Mysql学习总结(70)——MySQL 优化实施方案
查看>>