单链表反转(Singly Linked Lists in Java)

单链表反转(Singly Linked Lists in Java)

博客分类:

Java代码  

  1. package dsa.linkedlist;
  2. public class Node<E>{
  3. E data;
  4. Node<E> next;
  5. }

Java代码  

  1. package dsa.linkedlist;
  2. public class ReverseLinkedListRecursively {
  3. public static void main(String args[]) {
  4. ReverseLinkedListRecursively reverser = new ReverseLinkedListRecursively();
  5. SinglyLinkedList<Integer> originalList = reverser.getLabRatList(10);
  6. System.out.println("Original List : " + originalList.toString());
  7. originalList.start = reverser.reverse(originalList.start);
  8. System.out.println("Reversed List : " + originalList.toString());
  9. }
  10. public Node<Integer> reverse(Node<Integer> list) {
  11. if (list == null || list.next == null)
  12. return list;
  13. Node<Integer> nextItem = list.next;
  14. list.next = null;
  15. Node<Integer> reverseRest = reverse(nextItem);
  16. nextItem.next = list;
  17. return reverseRest;
  18. }
  19. private SinglyLinkedList<Integer> getLabRatList(int count) {
  20. SinglyLinkedList<Integer> sampleList = new SinglyLinkedList<Integer>();
  21. for (int i = 0; i < count; i++) {
  22. sampleList.add(i);
  23. }
  24. return sampleList;
  25. }
  26. }
  27. /*
  28. * SAMPLE OUTPUT Original List : 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 Reversed List : 9,
  29. * 8, 7, 6, 5, 4, 3, 2, 1, 0
  30. */

Java代码  

  1. package dsa.linkedlist;
  2. /**
  3. * This is a singly linked list with no prev pointer.
  4. * @author Braga
  5. * @param <E>
  6. */
  7. public class SinglyLinkedList<E> {
  8. Node<E> start;
  9. int size;
  10. public SinglyLinkedList(){
  11. start = null;
  12. size = 0;
  13. }
  14. //insertAtLast
  15. public void add(E data){
  16. insertAtLast(data);
  17. }
  18. public void insertAtLast(E data){
  19. if(size==0){
  20. start = new Node<E>();
  21. start.next = null;
  22. start.data = data;
  23. }else{
  24. Node<E> currentNode = getNodeAt(size-1);
  25. Node<E> newNode = new Node<E>();
  26. newNode.data = data;
  27. newNode.next = null;
  28. currentNode.next = newNode;
  29. }
  30. size++;
  31. }
  32. public void insertAtFirst(E data){
  33. if(size==0){
  34. start = new Node<E>();
  35. start.next = null;
  36. start.data = data;
  37. }else{
  38. Node<E> newNode = new Node<E>();
  39. newNode.data = data;
  40. newNode.next = start;
  41. start = newNode;
  42. }
  43. size++;
  44. }
  45. public Node<E> getNodeAt(int nodePos) throws ArrayIndexOutOfBoundsException{
  46. if(nodePos>=size || nodePos<0){
  47. throw new ArrayIndexOutOfBoundsException();
  48. }
  49. Node<E> temp = start;//Move pointer to front
  50. int counter = 0;
  51. for(;counter<nodePos;counter++){
  52. temp = temp.next;
  53. }
  54. return temp;
  55. }
  56. public void insertAt(int position, E data){
  57. if(position == 0){
  58. insertAtFirst(data);
  59. }else if(position==size-1){
  60. insertAtLast(data);
  61. }else{
  62. Node<E> tempNode = getNodeAt(position-1);
  63. Node<E> newNode = new Node<E>();
  64. newNode.data = data;
  65. newNode.next = tempNode.next;
  66. tempNode.next = newNode;
  67. size++;
  68. }
  69. }
  70. public Node<E> getFirst(){
  71. return getNodeAt(0);
  72. }
  73. public Node<E> getLast(){
  74. return getNodeAt(size-1);
  75. }
  76. public E removeAtFirst(){
  77. if(size==0){
  78. throw new ArrayIndexOutOfBoundsException();
  79. }
  80. E data = start.data;
  81. start = start.next;
  82. size--;
  83. return data;
  84. }
  85. public E removeAtLast(){
  86. if(size==0){
  87. throw new ArrayIndexOutOfBoundsException();
  88. }
  89. Node<E> tempNode = getNodeAt(size-2);
  90. E data = tempNode.next.data;
  91. tempNode.next = null;
  92. size--;
  93. return data;
  94. }
  95. public E removeAt(int position){
  96. if(position==0){
  97. return removeAtFirst();
  98. }else if(position == size-1){
  99. return removeAtLast();
  100. }else{
  101. Node<E> tempNode = getNodeAt(position-1);
  102. E data = tempNode.next.data;
  103. tempNode.next = tempNode.next.next;
  104. size--;
  105. return data;
  106. }
  107. }
  108. public int size(){
  109. return size;
  110. }
  111. public String toString(){
  112. if(size==0){
  113. return "";
  114. }else{
  115. StringBuilder output = new StringBuilder();
  116. Node<E> tempNode = start;
  117. while(tempNode.next!=null){
  118. output.append(tempNode.data).append(", ");
  119. tempNode = tempNode.next;
  120. }
  121. output.append(tempNode.data);
  122. return output.toString();
  123. }
  124. }
  125. }

Java代码  

 

 
package dsa.linkedlist;  

public class Node<E>{
 E data;
 Node<E> next;
} 

Java代码  

package dsa.linkedlist;  

public class ReverseLinkedListRecursively {  

    public static void main(String args[]) {
        ReverseLinkedListRecursively reverser = new ReverseLinkedListRecursively();
        SinglyLinkedList<Integer> originalList = reverser.getLabRatList(10);
        System.out.println("Original List : " + originalList.toString());
        originalList.start = reverser.reverse(originalList.start);
        System.out.println("Reversed List : " + originalList.toString());
    }  

    public Node<Integer> reverse(Node<Integer> list) {
        if (list == null || list.next == null)
            return list;
        Node<Integer> nextItem = list.next;
        list.next = null;
        Node<Integer> reverseRest = reverse(nextItem);
        nextItem.next = list;
        return reverseRest;
    }  

    private SinglyLinkedList<Integer> getLabRatList(int count) {
        SinglyLinkedList<Integer> sampleList = new SinglyLinkedList<Integer>();
        for (int i = 0; i < count; i++) {
            sampleList.add(i);
        }
        return sampleList;
    }
}
/*
 * SAMPLE OUTPUT Original List : 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 Reversed List : 9,
 * 8, 7, 6, 5, 4, 3, 2, 1, 0
 */  

Java代码  

package dsa.linkedlist;  

/**
 * This is a singly linked list with no prev pointer.
 * @author Braga
 * @param <E>
 */
public class SinglyLinkedList<E> {  

 Node<E> start;
 int size;  

 public SinglyLinkedList(){
  start = null;
  size = 0;
 }  

 //insertAtLast
 public void add(E data){
  insertAtLast(data);
 }  

 public void insertAtLast(E data){
  if(size==0){
   start = new Node<E>();
   start.next = null;
   start.data = data;
  }else{
   Node<E> currentNode = getNodeAt(size-1);
   Node<E> newNode = new Node<E>();
   newNode.data = data;
   newNode.next = null;
   currentNode.next = newNode;
  }
  size++;
 }  

 public void insertAtFirst(E data){
  if(size==0){
   start = new Node<E>();
   start.next = null;
   start.data = data;
  }else{
   Node<E> newNode = new Node<E>();
   newNode.data = data;
   newNode.next = start;
   start = newNode;
  }
  size++;
 }  

 public Node<E> getNodeAt(int nodePos) throws ArrayIndexOutOfBoundsException{
  if(nodePos>=size || nodePos<0){
   throw new ArrayIndexOutOfBoundsException();
  }
  Node<E> temp = start;//Move pointer to front
  int counter = 0;
  for(;counter<nodePos;counter++){
   temp = temp.next;
  }
  return temp;
 }  

 public void insertAt(int position, E data){
  if(position == 0){
   insertAtFirst(data);
  }else if(position==size-1){
   insertAtLast(data);
  }else{
   Node<E> tempNode = getNodeAt(position-1);
   Node<E> newNode = new Node<E>();
   newNode.data = data;
   newNode.next = tempNode.next;
   tempNode.next = newNode;
   size++;
  }
 }  

 public Node<E> getFirst(){
  return getNodeAt(0);
 }  

 public Node<E> getLast(){
  return getNodeAt(size-1);
 }  

 public E removeAtFirst(){
  if(size==0){
   throw new ArrayIndexOutOfBoundsException();
  }
  E data = start.data;
  start = start.next;
  size--;
  return data;
 }  

 public E removeAtLast(){
  if(size==0){
   throw new ArrayIndexOutOfBoundsException();
  }
  Node<E> tempNode = getNodeAt(size-2);
  E data = tempNode.next.data;
  tempNode.next = null;
  size--;
  return data;
 }  

 public E removeAt(int position){
  if(position==0){
   return removeAtFirst();
  }else if(position == size-1){
   return removeAtLast();
  }else{
   Node<E> tempNode = getNodeAt(position-1);
   E data = tempNode.next.data;
   tempNode.next = tempNode.next.next;
   size--;
   return data;
  }
 }  

 public int size(){
  return size;
 }  

 public String toString(){
  if(size==0){
   return "";
  }else{
   StringBuilder output = new StringBuilder();
   Node<E> tempNode = start;
   while(tempNode.next!=null){
    output.append(tempNode.data).append(", ");
    tempNode = tempNode.next;
   }
   output.append(tempNode.data);
   return output.toString();
  }
 }  

}  

单链表反转(Singly Linked Lists in Java)

时间: 2024-11-09 03:41:17

单链表反转(Singly Linked Lists in Java)的相关文章

单链表反转java代码

据说单链表反转问题面试中经常问,而链表这个东西相对于数组的确稍微难想象,因此今天纪录一下单链表反转的代码. 1,先定义一个节点类. 1 public class Node { 2 int index; 3 Node next; 4 5 public Node(int index, Node next) { 6 this.index = index; 7 this.next = next; 8 } 9 } 2,我一共写了三种方法 (1)迭代法.先将下一节点纪录下来,然后让当前节点指向上一节点,再将

Java实现单链表反转

本文主要介绍单链表反转的两种方法,记录如下: 1. package com.leetcode; public class ListReverse { public static void main(String[] args) { Node node1 = new Node(1); Node node2 = new Node(2); Node node3 = new Node(3); Node node4 = new Node(4); node1.next = node2; node2.next

【算法导论学习-23】两个单链表(single linked)求交点

问题:A.B两个单链表如果有交点,返回第一个交点在A中的位置(链表头结点位置为0). 分析:A.B如果有交点,交点的后继一定也是交点,所以一定是Y型相交,所以算法的思想如下 1)  求得A.B的长度,比如ALength,Blength 2)  判断ALength,Blength谁大,比如Alength>Blength 3)  Alength移动到Alength-Blength的位置,开始判断每个节点是否相等,相等则退出. 以本博客中"[算法导论学习-20]单链表(single linked

单链表反转问题

单链表反转问题 基本问题 如何将单链表反转? 算法实现 /** * * Description: 单链表反转. * * @param head * @return ListNode */ public static ListNode reverseList(ListNode head) { if (head == null) { return head; } ListNode prev = null; ListNode current = head; ListNode next = null;

单链表反转的2种方法

1 public class ReverseDemo { 2 3 /** 4 * 单链表反转的两种方法 5 */ 6 public static void main(String[] args) { 7 Node head =new Node("a"); 8 Node node2=new Node("b"); 9 Node node3=new Node("c"); 10 head.setNext(node2); 11 node2.setNext(

链表 单链表反转

思路1:O(n^2). “狸猫换太子”,不进行改动链表结构,只首尾交换len/2次.但是在本函数中用到了定位函数,定位函数实际上是遍历了一遍整个链表,所以综合效率很低,达到O(n^2). //单链表反转(O(n^2)) void reverseList(Node* Head) { int count = numOfNodes(Head); //首尾交换 for(int i=1; i<=count/2; i++) { Node* p1 = locateNodeI(Head, i); Node* p

单链表反转C语言实现

单链表的反转可以使用循环,也可以使用递归的方式 1.循环反转单链表 循环的方法中,使用pre指向前一个结点,cur指向当前结点,每次把cur->next指向pre即可. 代码: # include <iostream> # include <cstdlib> using namespace std; struct linkNode { int val; linkNode *next; linkNode(int x):val(x),next(NULL){} }; linkNod

单链表反转python实现

单链表的反转可以使用循环,也可以使用递归的方式 1.循环反转单链表 循环的方法中,使用pre指向前一个结点,cur指向当前结点,每次把cur->next指向pre即可. 代码: class ListNode: def __init__(self,x): self.val=x; self.next=None; def nonrecurse(head): #循环的方法反转链表 if head is None or head.next is None: return head; pre=None; c

数据结构 单链表反转 回顾练习

之前写了一个单链表反转,但是使用的新的空间. 这次的反转是不修改原来的结构,直接将节点内的元素进行修改 1 #!/usr/bin/env python3 2 3 class LNode(object): 4 def __init__(self, elem, next_=None): 5 self.elem = elem 6 self.next = next_ 7 8 class ListError(Exception): 9 pass 10 11 class LList(object): 12