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

河北中保建设集团网站首页网站制作的流程

河北中保建设集团网站首页,网站制作的流程,大连做网站价钱,为什么做织梦网站时图片出不来文章目录力扣24.两两交换链表中的节点题目描述方法1:非递归方法2:递归力扣24.两两交换链表中的节点 题目描述 给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题&…

文章目录

  • 力扣24.两两交换链表中的节点
    • 题目描述
    • 方法1:非递归
    • 方法2:递归

力扣24.两两交换链表中的节点

题目描述

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

示例 1:

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

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

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

提示:

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

方法1:非递归

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
struct ListNode* swapPairs(struct ListNode* head){if(head==NULL||head->next==NULL) return head;//如果是空链表或者只有一个元素则直接返回struct ListNode *p=head,*t,*pre=NULL;if(p->next!=NULL) head=p->next;//直接指定最终的返回位置,即应当是原始第二个节点(不为空)while(p!=NULL){t=p->next->next;//记录后继节点的下一个位置if(pre!=NULL) pre->next=p->next;//将前驱节点接到后续节点上,防止断链pre=p;//将本节点标记为下一次的前驱节点p->next->next=p;//交换相邻节点,即让相邻节点的后继指针指向当前节点p->next=t;//当前节点的后继指针指向原后继节点的后继p=t;//更新当前节点的位置,准备进行下一次交换if(p!=NULL&&p->next==NULL) return head;//如果更新后只剩下单独一个节点了则不用再交换了,立即返回结果}return head;
}

方法2:递归

从第一个节点开始,要通过递归的方式寻找交换之后该节点的下一个节点,规律是:

  • 第1个节点的下一个节点是下一个节点的下一个节点,即第3个节点
  • 第2个节点的下一个节点是第1个节点
  • 以此类推

递归函数中其中一个重大的作用就是为它的上一级调用函数返回需要的节点作为上一级递归中的下一个节点,我们暂存这个节点,在需要结束时返回给上一级函数。

struct ListNode *p=head->next;

同时我们通过调用下一级递归函数的方式来期望获得当前节点交换后连接的下一个节点,注意一次调用的步长为2,即隔一个节点进行下一次调用:

head->next=swapPairs(head->next->next);

并且根据规律,本节点的前驱节点也应改成本节点的原后继节点,即上面暂存的节点P

p->next=head;

最终递归函数完整应写成如下形式:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
struct ListNode* swapPairs(struct ListNode* head){if(head==NULL||head->next==NULL) return head;//如果节点为空或者只剩单一节点终止递归,返回struct ListNode *p=head->next;//记录当前节点的下一个节点head->next=swapPairs(head->next->next);p->next=head;return p;
}
http://www.ds6.com.cn/news/27738.html

相关文章:

  • 网页设计实训总结600字西安网站seo哪家公司好
  • 做数据分析好看的网站搜索引擎优化seo名词解释
  • 佛山网站建设联系电话网站制作和推广
  • 上海网站建设市场分析厦门seo网站排名优化
  • APP开发网站建设哪家好企业网站优化服务
  • 做网站怎么qq邮箱验证武汉千锋教育培训机构怎么样
  • 合肥网站优化价格优化seo深圳
  • 付费的网站是指自动的网站设计制作
  • 隧道建设网站怎么了seo招聘职责
  • 做网站小程序重庆seo什么意思
  • Wordpress屏蔽模仿站爬虫ip苏州百度推广代理商
  • 信息技术网站建设专业百度的特点和优势
  • 在哪个网站做一照一码网上推广的平台有哪些
  • 高端广告公司网站建设东莞网络营销全网推广
  • 网页设计培训机构推荐seo搜索铺文章
  • 咋么做网站在电脑上网站google搜索优化
  • 有口碑的武进网站建设百度关键词搜索技巧
  • 管理员网站后台上传本地视频互联网平台推广怎么做
  • 做点心的网站信息流投放平台
  • 镇江域名注册广州市口碑seo推广
  • 制作团购网站志鸿优化网官网
  • 杭州网站建设迅雷磁力链bt磁力天堂下载
  • 西安做网站的公司维护百度网盘电话人工服务
  • 外国黄色网站自己的网站怎么做seo
  • 重庆网站建设联系电话推广运营是做什么的
  • 免费企业名录网站手机百度账号登录入口
  • 企业网站建设费用计入哪个科目石家庄全网seo
  • 手机优化不到100怎么办网站排名优化手机
  • 国产99做视频网站长沙seo公司排名
  • 温州网页网站制作怎样在网上做推广