java LinkedList的实例详解

网友投稿 256 2023-04-10


java LinkedList的实例详解

java LinkedList的实例详解

站在Java的角度看,玩队列不就是玩对象引用对象嘛!

实例代码:

public class LinkedList implements List, Deque {

Node first;

Node last;

int size;

public boolean add(E e) {

final Node l = last;

final Node newNode = new Node<>(l, e, null);

last = newNode;

if (l == null)

first = newNode;

else

l.next = newNode;

size++;

modCount++;

return true;

}

private static class Node<E> {

E item;

Node next;

Node prev;

Node(Node prev, E element, Node next) {

this.item = element;

this.next = next;

this.prev = prev;

}

}

}

单链表反转:

/**

* 递归,在反转当前节点之前先反转后续节点

*/

public static Node reverse(Node head) {

if (null == head || null == head.getNextNode()) {

return head;

}

Node reversedHead = reverse(head.getNextNode());

head.getNextNode().setNextNode(head);

head.setNextNode(null);

return reversedHead;

}

sVThrzrL

/**

* 遍历,将当前节点的下一个节点缓存后更改当前节点指针

*

*/

public static Node reverse2(Node head) {

if (null == head) {

return head;

}

Node pre = head;

Node cur = head.getNextNode();

Node next;

while (null != cur) {

next = cur.getNextNode();

cur.setNextNode(pre);

pre = cur;

cur = next;

}

//将原链表的头节点的下一个节点置为null,再将反转后的头节点赋给head

head.setNextNode(null);

head = pre;

return head;

}

对于数组问题,一般我们要新建数组,必要时移动下标

以上就是java LinkedList 的实例,如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:MyBatis创建存储过程的实例代码_动力节点Java学院整理
下一篇:Spring MVC 中获取session的几种方法(小结)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~