码迷,mamicode.com
首页 > 其他好文 > 详细

26、输入一个链表,反转链表后,输出链表的所有元素。

时间:2017-06-23 22:01:25      阅读:156      评论:0      收藏:0      [点我收藏+]

标签:链表   ret   代码   pre   tno   int   class   技术   元素   

 输入一个链表,反转链表后,输出链表的所有元素。

 

思路:

 ListNode next = null;//用来保存待反序的第一个节点(head 和 next节点)

ListNode pre = null;//用来保存已经反序的第一个结点

 

next = head.next;//首先记录当前节点的下一个节点,(保存起来)

//先用next保存head的下一个节点的信息,保证单链表不会因为失去head节点的原next节点而就此断裂

head.next = pre;//让当前节点指向前一个节点,因为要反序

//保存完next,就可以让head从指向next变成指向pre了

 

pre = head;//让前一个节点值,取代当前的节点值。因为要继续向下走

//head指向pre后,就继续依次反转下一个节点

 

head = next;//让下一个节点,取代当前节点

 //让pre,head,next依次向后移动一个节点,继续下一次的指针反转

技术分享

 1 /*
 2 public class ListNode {
 3     int val;
 4     ListNode next = null;
 5 
 6     ListNode(int val) {
 7         this.val = val;
 8     }
 9 }*/
10 public class Solution {
11     public ListNode ReverseList(ListNode head) {
12     ListNode pre = null;
13     ListNode next = null;
14     while (head != null) {
15         next = head.next;
16         head.next = pre;
17         pre = head;
18         head = next;
19     }
20     return pre;
21 }
22 }

技术分享

c++代码:

技术分享

 

26、输入一个链表,反转链表后,输出链表的所有元素。

标签:链表   ret   代码   pre   tno   int   class   技术   元素   

原文地址:http://www.cnblogs.com/olivegyr/p/7071615.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!