剑指offer-反转链表

输入一个链表,反转链表后,输出新链表的表头。

思路
遍历链表,使用cur保存当前节点,将cur的下一个指向前一个

Java

/*
public class ListNode {
    int val;
    ListNode next = null;

    ListNode(int val) {
        this.val = val;
    }
}*/
public class Solution {
  public ListNode ReverseList(ListNode head) {
    ListNode cur = head;
    ListNode pre = null;
    while (cur != null) {
      ListNode next = cur.next;
      cur.next = pre;
      pre = cur;
      cur = next;
    }
    return pre;
  }
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 题目 定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点。 链表结点定义 分析 为了正确的反转...
    Longshihua阅读 247评论 0 1
  • 题目描述 反转链表 输入一个链表,反转链表后,输出新链表的表头。 解题思路 转自 https://blog.csd...
    一只可爱的柠檬树阅读 189评论 0 0
  • 题目描述 输入一个链表,反转链表后,输出新链表的表头。 解题思路 设置三个指针,head为当前节点,pre为当前节...
    繁著阅读 261评论 0 0
  • 题目描述 输入一个链表,反转链表后,输出新链表的表头。 时间限制:1秒 空间限制:32768K 热度指数:4820...
    KEEPINUP阅读 477评论 0 3
  • 题目描述 输入一个链表,反转链表后,输出新链表的表头。 思路 定义三个指针,分别指向当前结点的前一个结点,当前结点...
    云胡同学阅读 149评论 0 0