翻转链表力扣链接
反转一个单链表。
示例:
输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL
我先贴出自己愚笨的方案
//s迭代 public ListNode reverseList(ListNode head) { ListNode pre = head; ListNode fa = pre; List<Integer> list = new ArrayList<Integer>(); while(head!=null) { list.add(head.val); head = head.next; } for (int i = list.size()-1; i >= 0; i--) { pre.val = list.get(i); pre = pre.next; } return fa; }
我写的代码质量也就这水平了,哈哈,一个字,菜
咱们来看一下官方
public ListNode reverseList(ListNode head) { //申请节点,pre和 cur,pre指向null ListNode pre = null; ListNode cur = head; ListNode tmp = null; while(cur!=null) { //记录当前节点的下一个节点 tmp = cur.next; //然后将当前节点指向pre cur.next = pre; //pre和cur节点都前进一位 pre = cur; cur = tmp; } return pre; }
实在是高级
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于