码迷,mamicode.com
首页 > 编程语言 > 详细

Java 单链表的倒置

时间:2014-06-08 22:22:59      阅读:352      评论:0      收藏:0      [点我收藏+]

标签:c   style   class   blog   code   java   

在面试,笔试的过程中经常会遇到面试官问这种问题,实现单链表的倒置方法。现在对单链表的倒置犯法做个记录,方便自己以后查看。

单链表的定义:

bubuko.com,布布扣
 1 public class Node {
 2 
 3     int v;    
 4     Node next;
 5     public Node(){        
 6     }
 7     public Node(int v){        
 8         this.v = v;
 9     }
10     
11     public int getV() {
12         return v;
13     }
14     public void setV(int v) {
15         this.v = v;
16     }
17     public Node getNext() {
18         return next;
19     }
20     public void setNext(Node next) {
21         this.next = next;
22     }
23 }
View Code

单链表的倒置方法有两种:递归的和非递归的。下边分别介绍:

递归:

bubuko.com,布布扣
1 public static Node reverse(Node head){
2         if(head == null || head.next==null){
3             return head;
4         }
5         Node reverseHead = reverse1(head.next);
6         head.getNext().setNext(head);
7         head.setNext(null);
8         return reverseHead;
9     }
View Code

非递归:

bubuko.com,布布扣
 1 /**
 2      * 非递归实现
 3      * @param head
 4      * @return
 5      */
 6     public static Node reverse(Node head){
 7         if (head == null) return head;
 8         Node pNode=head;
 9         Node cur = head.next;
10         Node nNode=null;
11         while(cur!=null){
12             nNode = cur.next;
13             cur.setNext(pNode);
14             pNode = cur;
15             cur = nNode;
16         }
17         head.setNext(null);
18         return pNode;
19     }
View Code

递归与非递归的实现和斐波那契函数的非递归实现很像。

 

Java 单链表的倒置,布布扣,bubuko.com

Java 单链表的倒置

标签:c   style   class   blog   code   java   

原文地址:http://www.cnblogs.com/weilq/p/3775520.html

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