一、链表(单链表反转)

在链表遍历的过程中将指针顺序置换,代码如下

public static Node<String> reverse(Node<String> head) {
        Node<String> pre = null;
        Node<String> next = null;
        while (head != null) {
            next = head.next;
            head.next = pre;
            pre = head;
            head = next;
        }
        return pre;
        /*
        第一次遍历
        A -> B -> C -> D -> E -> F
        ^    ^
        |    |
        head next
        next = head.next; // next 指向 B
        head.next = pre;  // head.next = null,此时 head = A
        pre = head;       // pre = A
        head = next;      // head 指向B

        遍历后
         B -> C -> D -> E -> F           A
         ^                               ^
         |                               |
         head                           pre

        第二次遍历
        B -> C -> D -> E -> F
        ^    ^
        |    |
        head next
        next = head.next; // next 指向 C
        head.next = pre;  // head.next = A,此时 head = B -> A
        pre = head;       // pre = B -> A
        head = next;      // head 指向 C

         遍历后
         C -> D -> E -> F            B -> A
         ^                           ^
         |                           |
         head                        pre

         ………………
         */
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值