当前位置: 首页 > news >正文

网站及建设中页面廊坊百度推广电话

网站及建设中页面,廊坊百度推广电话,html网站完整代码,做网站商标分类每日一题(LeetCode)----链表–两两交换链表中的节点 1.题目([24. 两两交换链表中的节点](https://leetcode.cn/problems/spiral-matrix/)) 给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内…

每日一题(LeetCode)----链表–两两交换链表中的节点

1.题目([24. 两两交换链表中的节点](https://leetcode.cn/problems/spiral-matrix/))

  • 给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。

    示例 1:

    在这里插入图片描述

    输入:head = [1,2,3,4]
    输出:[2,1,4,3]
    示例 2:

    输入:head = []
    输出:[]
    示例 3:

    输入:head = [1]
    输出:[1]

    提示:

    链表中节点的数目在范围 [0, 100] 内
    0 <= Node.val <= 100

2.解题思路

思路一

先拆分成两个链表之后再进行合并
1.拆分

我们遍历一遍原链表,通过下标的奇偶拆分成两个链表

2.合并

(1)我们以通过下标为奇数得到的链表的表头作为新链表的表头,然后用两个指针变量交叉遍历两个链表(交叉遍历就是一个链表向后遍历了一个节点之后就换另一个链表向后遍历一个节点,这样循环,直到两个链表都遍历完成结束)

(2)将遍历到的节点放到新链表中即可(这里说是放到新链表中实际上只是改变了两个链表中的指针指向)

(3)最后我们返回这个新链表的表头

注意:如果给出的链表没有节点或者只有一个节点,我们不需要进行操作,直接返回原有链表即可
思路二:迭代法
1.我们创建一个虚拟头节点方便我们进行迭代操作,如下图

在这里插入图片描述

2.遍历链表实现两两交换

如果当前操作节点的下一个和当前操作节点的下一个的下一个的下一个同时不为空,进行下面操作

先保存一下当前操作节点的下一个节点和下一个的下一个节点为临时节点一和临时节点二

第一步:当前操作节点的下一个指向操作开始的节点的下一个的下一个, 第二步:当前操作节点的下一个的下一个指向临时节点一 第三步:当前操作节点的下一个的下一个的下一个指向临时节点二 第四步:下一次操作节点为当前操作节点的下一个的下一个,继续进行操作

看下图进行理解

在这里插入图片描述

思路三:递归法

递归的终止条件是链表中没有节点,或者链表中只有一个节点,此时无法进行交换。

如果链表中至少有两个节点,则在两两交换链表中的节点之后,原始链表的头节点变成新的链表的第二个节点,原始链表的第二个节点变成新的链表的头节点。链表中的其余节点的两两交换可以递归地实现。在对链表中的其余节点递归地两两交换之后,更新节点之间的指针关系,即可完成整个链表的两两交换。

3.写出代码

思路一的代码
class Solution {
public:ListNode* swapPairs(ListNode* head) {//如果链表中没有元素,那么返回链表即可if(head==nullptr||head->next==nullptr){return head;}//拆成两个链表ListNode* head1=head;ListNode* head2=head->next;ListNode* Temp1=head1;ListNode* Temp2=head2;//进行拆分int flag=0;while(Temp1&&Temp2){if(flag%2==0){Temp1->next=Temp2->next;Temp1=Temp1->next;flag++;}else{Temp2->next=Temp1->next;Temp2=Temp2->next;flag++;}}Temp1=head1;Temp2=head2;flag=0;while(Temp1&&Temp2){if(flag%2==0){ListNode* delay2=Temp2->next;Temp2->next=Temp1;Temp2=delay2;flag++;}else{ListNode* delay1=Temp1->next;Temp1->next=Temp2;Temp1=delay1;flag++;}}return head2;}
};
思路二的代码
class Solution {
public:ListNode* swapPairs(ListNode* head) {ListNode* dummyhead=new ListNode(0);dummyhead->next=head;ListNode* cur=dummyhead;while(cur->next!=nullptr&&cur->next->next!=nullptr){ListNode* temp1=cur->next;ListNode* temp2=cur->next->next->next;cur->next=cur->next->next;cur->next->next=temp1;cur->next->next->next=temp2;cur=cur->next->next;}return dummyhead->next;}
};
思路三的代码
class Solution {
public:ListNode* swapPairs(ListNode* head) {if(head==nullptr||head->next==nullptr){return head;}ListNode* newHead=head->next;head->next=swapPairs(newHead->next);newHead->next=head;return newHead;}
};
http://www.15wanjia.com/news/173425.html

相关文章:

  • kuler 网站报电子商务( 网站建设与运营)
  • 上海网站公司建设ppt模板下载免费素材网站
  • 网站logo如何替换网站建设买了域名
  • 泽国镇规划建设局网站wordpress上传本地主题
  • 网站建设中静态页面模板广告设计网址
  • 电子商务网站平台建设前景展望导航网站怎么推广
  • 游戏网站做代理肇东网页设计
  • 网站访问速度查询如何建立和设计公司网站作文
  • 网站搭建报价单怎么用群晖做网站
  • 与电子商务网站建设有关实训报告wordpress读取相册
  • 单人给一个公司做网站费用手机芒果tv2016旧版
  • 深圳网站制作联系电话免费优化网站排名
  • 可以自己做网站如何找做网站的客户
  • 网站开发的工作自适应网站推广
  • 网站备案期广告公司设计
  • 摄影网站建设任务书买域名去哪个网站
  • 桂平网站设计网站排名稳定后后期如何优化
  • 网站建设管理工作简述做博客网站赚钱
  • 建立网站的平台源服务器发生5xx错误
  • 门户网站建设方案内容设计网站页面好处
  • 在网站做博客做网站用框架
  • 门户网站开发步骤黄山网站开发jidela
  • 碑林网站制作郑网站建设
  • 北京做网站建设代写稿子的平台
  • 如何选择做pc端网站网络舆情监测专升本对口专业
  • 网站服务器搭建及配置的具体步骤医疗网站设计图
  • 有域名如何建网站中国国际贸易单一窗口网站
  • 网站做的比较好的海南省建设标准定额网站
  • eclipes网站建设教程百度竞价排名榜
  • 官方网站建设调研报告筑巢网站建设