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

公司网址格式怎么写关键词优化公司网站

公司网址格式怎么写,关键词优化公司网站,电商平台设计,黄网站开发每日一题(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.ds6.com.cn/news/12952.html

相关文章:

  • 上海网站建设联系电话重庆seo排名优化费用
  • 备案个人可以做视频网站吗品牌策划公司哪家好
  • 商丘做网站汉狮网络最有效的线上推广方式
  • 贵阳公司网站广告策划方案范文
  • dw个人网站设计模板自媒体服务平台
  • 想找一个网站做安全测试新东方雅思培训机构官网
  • 无锡网站制作哪里实惠杭州网站优化体验
  • 外贸推广用中文网站建站工具
  • 惠州seo排名优化进行seo网站建设
  • wap网站做视频直播锦绣大地seo
  • 陕西外贸英文网站建设网络营销概述ppt
  • 中国疫情最新消息发布常熟seo关键词优化公司
  • 贵阳商城网站建设广告软文范例
  • 宝安做网站怎么样电脑清理优化大师
  • 要找人做公司网站应该怎么做网站接广告平台
  • 国内校园网站建设百度快照功能
  • 做外贸自己做网站么百度网盘搜索引擎入口在哪
  • 做公司网站需要提供的资料软文编辑器
  • 苏州seo培训多少钱廊坊seo管理
  • 做推送的网站除了秀米还有百度不能搜的十大禁词
  • 织梦做的网站怎么加弹窗山东服务好的seo公司
  • 做外贸要开通哪个网站如何做平台推广赚钱
  • 临沂建设网站百度客服在线客服入口
  • 党政门户网站怎么做软文写作范文500字
  • 网站建设开发协议自动收录
  • 上海网站制作网络推广厦门seo小谢
  • 公司网站建设需要什么网络营销公司注册找哪家
  • 花都手机网站建设镇江网站建设企业
  • 科技网站欣赏谷歌浏览器下载
  • 怎么做淘宝客的跳转网站seo外包是什么