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

做 淘宝客最大的网站是叫什么名字平台建设包括什么

做 淘宝客最大的网站是叫什么名字,平台建设包括什么,旅游电商网站开发,基于mvc4商务网站开发反转链表题目描述 给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。 题解1-迭代 假设链表为 1→2→3→∅,我们想要把它改成 ∅←1←2←3。 在遍历链表时,将当前节点的 next 指针改为指向前一个节点。由于节点没…

反转链表题目描述

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。
在这里插入图片描述
在这里插入图片描述

题解1-迭代

假设链表为 1→2→3→∅,我们想要把它改成 ∅←1←2←3。

在遍历链表时,将当前节点的 next 指针改为指向前一个节点。由于节点没有引用其前一个节点,因此必须事先存储其前一个节点。在更改引用之前,还需要存储后一个节点。最后返回新的头引用。

// 函数:反转单链表
struct ListNode* reverseList(struct ListNode* head) {// 初始化前驱节点为 NULLstruct ListNode* prev = NULL;// 当前节点指向头节点struct ListNode* curr = head;// 循环直到当前节点为空(到达链表末尾)while (curr) {// 临时保存当前节点的下一个节点struct ListNode* next = curr->next;// 将当前节点的指针指向前驱节点,完成反转curr->next = prev;// 更新前驱节点为当前节点prev = curr;// 更新当前节点为下一个节点curr = next;}// 循环结束时,prev 指向原链表的尾节点,也就是反转后链表的头节点// 返回 prev,即反转后的链表头节点return prev;
}

在上述代码中,prev 并不是直接加入节点的。相反,prev 是用来指向当前节点的前一个节点的。在链表反转过程中,prev 会跟随着 curr 节点向前移动,而 curr 则指向当前正在处理的节点。加入节点的顺序是通过将当前节点的 next 指针指向前一个节点来实现的,从而改变了链表的连接顺序,达到反转链表的效果。

具体来说,在代码中的循环中,每一次迭代都会执行以下操作:

  1. 将当前节点 curr 的下一个节点保存到临时变量 next 中。
  2. 将当前节点 currnext 指针指向前一个节点 prev,实现了链表节点的反转。
  3. 更新 prev 指向 curr,将 curr 设为下一轮迭代的前驱节点。
  4. curr 设为 next,准备处理下一个节点。

通过不断迭代链表,并在每一步中更新指针的指向,实现了链表的反转。这样,循环结束时,prev 指向的是原链表的尾节点,即新的头节点,完成了链表的反转。

题解2递归

在这里插入图片描述

// 函数:反转单链表
struct ListNode* reverseList(struct ListNode* head) {// 如果链表为空或者只有一个节点,则直接返回头节点,因为反转后结果不变if (head == NULL || head->next == NULL) {return head;}// 递归调用,反转以头节点的下一个节点为头的子链表struct ListNode* newHead = reverseList(head->next);// 将当前头节点的下一个节点的下一个节点指向当前头节点,实现链表反转head->next->next = head;// 将当前头节点的下一个节点指向 NULL,防止形成环head->next = NULL;// 返回反转后的新头节点return newHead;
}

这段代码实现了一个递归方法来反转单链表。它的思路是先递归地反转以头节点的下一个节点为头的子链表,然后将当前头节点的下一个节点的 next 指针指向当前头节点,再将当前头节点的 next 指针指向 NULL,最后返回反转后的新头节点。

这种递归方法的关键是理解递归的调用过程,以及在每一级递归中如何改变链表节点之间的连接关系,从而实现链表的反转。

作者:力扣官方题解
链接:https://leetcode.cn/problems/reverse-linked-list/solutions/551596/fan-zhuan-lian-biao-by-leetcode-solution-d1k2/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

http://www.yayakq.cn/news/729857/

相关文章:

  • 广州番禺营销型网站建设校园网站制作模板
  • ui作品集 网站怎么做盘锦网站建设多少钱
  • 商丘销售网站制作白宫 wordpress
  • 加强人社网站建设在线制作假亲子鉴定书
  • 旅游网站建设的总结wordpress 显示子菜单
  • 网站 模块杭州网站建设响应式
  • 滨江区做网站公司万能网页视频下载
  • 微信微网站开通wordpress填写信息插件
  • 湖北省城建设计院网站陕西手机网站建设
  • 北滘高明网站建设做柜子的常去的网站
  • 知名做网站公司学校网站模板 dedecms
  • 怎么添加网站后台龙岗网站价格
  • 做游戏代练的网站开网店如何找货源和厂家
  • 帝国网站源码手机推广普通话主题班会记录
  • 试论述外贸网站建设应注意的问题网页建设企业
  • 茂名东莞网站建设广州网站建设好评公司
  • 在韩国申请网站域名需要什么网站建设的费用入账
  • 网站建设都需要哪些材料做网站要审核吗
  • 做投票链接网站西安关键字优化哪家好
  • 有没有什么网站做泰国的东西滕州盛扬网络公司网站建设推广
  • 江油网站建设网站建设流程信息
  • 微信建设银行官方网站台州做微网站
  • 购物网站首页设计5118关键词工具
  • 长春有微信网站一起整的吗装饰设计软件
  • 旅游网站怎么制作阿里云备案个人可以做网站吗
  • 上海市门户网站重庆专业做网站
  • 昌平网站建设哪家强企业如何全面开展品牌工程建设
  • wed网站北京网页设计公司兴田德润优秀
  • 新浪云计算 网站开发如何做专题网站
  • 做导航网站把别人的网址链接过来要经过允许吗天津建设银行官方网站