一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java實現單鏈表翻轉實例代碼

Java實現單鏈表翻轉實例代碼

2020-09-01 09:56Michael_YuChen Java教程

Java實現單鏈表反轉,遞歸和非遞歸兩種形式。接下來通過本文給大家分享Java實現單鏈表翻轉實例代碼,需要的的朋友參考下

Java實現單鏈表反轉,遞歸和非遞歸兩種形式

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
/**
 * 反轉單鏈表
 */
 
/** * 定義鏈表
 *
 * @author 16026
 *
 */
class Node {
  int val;
  Node next;
  public Node(int val) {
    this.val = val;
  }
}
public class ReverseList {
  /**
   * 反轉鏈表
   *
   * @param head
   * @return
   */
  public static Node reverseList(Node head) {
    if (head == null || head.next == null) {
      return head;
    }
    Node reHead = null;// 定義新鏈表頭結點
    while (head != null) {
      Node cur = head.next;// 記錄下一個節點
      head.next = reHead;// 將rehead節點連接到head節點上
      reHead = head;// 讓rehead指向head
      head = cur;// 將head指向下一個節點
    }
    return reHead;
  }
  /**
   * 遞歸反轉鏈表
   *
   * @param head
   * @return
   */
  public static Node reverseList2(Node head) {
    if (head == null || head.next == null)
      return head;
    Node rehead = reverseList2(head.next);
    head.next.next = head;// 將頭節點置于末端
    head.next = null;// 防止鏈表循環
    return rehead;
  }
  /**
   * 打印鏈表
   *
   * @param head
   */
  public static void printList(Node head) {
    if (head == null)
      return;
    while (head != null) {
      System.out.print(head.val + " ");
      head = head.next;
    }
  }
  /**
   * 測試
   *
   * @param args
   */
  public static void main(String[] args) {
    Node n1 = new Node(1);
    Node n2 = new Node(2);
    Node n3 = new Node(3);
    Node n4 = new Node(4);
    Node n5 = new Node(5);
    n1.next = n2;
    n2.next = n3;
    n3.next = n4;
    n4.next = n5;
    // Node rehead = reverseList(n1);
    Node rehead = reverseList2(n1);
    printList(rehead);
  }
}

運行結果如下:

Java實現單鏈表翻轉實例代碼

以上所述是小編給大家介紹的Java實現單鏈表翻轉實例代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對服務器之家網站的支持!

原文鏈接:http://blog.csdn.net/qq_21150865/article/details/65629749

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 波多野结衣被绝伦强在线观看 | 欧美视频一区二区三区在线观看 | 韩国甜性涩爱在线播放 | 日本精品人妖shemale人妖 | 91嫩草国产在线观看免费 | 好湿好紧好多水c | 免费亚洲一区 | 日韩精品成人a在线观看 | 好湿好紧太硬了我好爽 | 97国产蝌蚪视频在线观看 | 欧美1 | 韩国三级日本三级香港三级黄 | 国产专区亚洲欧美另类在线 | 亭亭色| 扒开老师挠尿口到崩溃刑罚 | 日韩欧美中文字幕一区 | 欧美在线视频7777kkkk | 男人桶女下面60分钟视频 | 四虎国产成人免费观看 | 女女同性做爰xxoo亲吻 | 视频一区二区 村上凉子 | 国产精品成人一区二区 | 亚欧成人中文字幕一区 | 久久re热在线视频精69 | 国产福利你懂的 | 亚洲精彩视频在线观看 | 国产成人精品1024在线 | 厨房里摸着乳丰满在线观看 | 黑人巨大初黑人解禁作品 | 日本高清中文 | gay台湾无套男同志可播放 | 国产欧美一区二区精品性色99 | 九九九久久久 | 青青国产在线视频 | 91桃色污| 久久se精品一区二区国产 | 国产精品玖玖玖影院 | 免费国产一级观看完整版 | 美女污视频在线观看 | 97香蕉超级碰碰碰久久兔费 | 红色一片在线影视 |