链表逆序的两种方法(java)

public class ListNode {

int val;

ListNode next;

public ListNode(int val) {

this.val = val;

}

}

1.用迭代的方法反转链表(iteratively)

class Solution {

public ListNode reverseList(ListNode head) {

if (head == null) {

return null;

}

ListNode dummy = new ListNode(0);

dummy.next = head;

ListNode pre = dummy.next;

ListNode start = pre.next;

ListNode then = start.next;

while (then != null) {

start.next = then.next;

then.next = pre.next;

pre.next = then;

then = start.next;

}

return dummy.next;

}

}

2.用递归的方法反转链表(recursively)

class Solution {

public ListNode reverseList(ListNode head){

if (head.next == null || head == null) {

return head;

}

ListNode nextNode = head.next;

ListNode last = reverseList(nextNode);

nextNode.next = head;

head.next = null;

return last;

}

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,859评论 0 33
  • //leetcode中还有花样链表题,这里几个例子,冰山一角 求单链表中结点的个数----时间复杂度O(n)这是最...
    暗黑破坏球嘿哈阅读 1,627评论 0 6
  • 一、基本数据类型 注释 单行注释:// 区域注释:/* */ 文档注释:/** */ 数值 对于byte类型而言...
    龙猫小爷阅读 4,403评论 0 16
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,326评论 19 139
  • ―我愿你,求而不得,思而不见,爱而不合,分而不聚,念我成疾,可好? ―我和你,数十年前,许下心愿,不分不离,数十年...
    药禾阅读 240评论 0 1

友情链接更多精彩内容