网站首页 > 文章中心 > 其它

双向链表查找代码java

作者:小编 更新时间:2023-09-02 10:49:05 浏览量:4人看过

用JAVA语言,编写一个链表类(双向链表),实现插入,删除,查找操作.新手,要俗易懂些,最好自己调适通过.急

定义接口:

//Deque.java

package dsa; //根据自己的程序位置不同

public interface Deque {

public int getSize();//返回队列中元素数目

public boolean isEmpty();//判断队列是否为空

双向链表查找代码java-图1

public Object first() throws ExceptionQueueEmpty;//取首元素(但不删除)

public Object last() throws ExceptionQueueEmpty;//取末元素(但不删除)

public void insertFirst(Object obj);//将新元素作为首元素插入

public void insertLast(Object obj);//将新元素作为末元素插入

public Object removeFirst() throws ExceptionQueueEmpty;//删除首元素

public Object removeLast() throws ExceptionQueueEmpty;//删除末元素

双向链表查找代码java-图2

public void Traversal();//遍历

}

双向链表实现:

//Deque_DLNode.java

/*

* 基于双向链表实现双端队列结构

*/

package dsa;

public class Deque_DLNode implements Deque {

protected DLNode header;//指向头节点(哨兵)

protected DLNode trailer;//指向尾节点(哨兵)

protected int size;//队列中元素的数目

//构造函数

public Deque_DLNode() {

header = new DLNode();

trailer = new DLNode();

header.setNext(trailer);

trailer.setPrev(header);

size = 0;

//返回队列中元素数目

public int getSize()

{ return size; }

//判断队列是否为空

public boolean isEmpty()

{ return (0 == size) ? true : false; }

//取首元素(但不删除)

public Object first() throws ExceptionQueueEmpty {

if (isEmpty())

throw new ExceptionQueueEmpty("意外:双端队列为空");

return header.getNext().getElem();

//取末元素(但不删除)

public Object last() throws ExceptionQueueEmpty {

return trailer.getPrev().getElem();

//在队列前端插入新节点

public void insertFirst(Object obj) {

DLNodesecond = header.getNext();

DLNodefirst = new DLNode(obj, header, second);

second.setPrev(first);

header.setNext(first);

size++;

//在队列后端插入新节点

public void insertLast(Object obj) {

DLNodesecond = trailer.getPrev();

DLNodefirst = new DLNode(obj, second, trailer);

second.setNext(first);

trailer.setPrev(first);

//删除首节点

public Object removeFirst() throws ExceptionQueueEmpty {

DLNodefirst = header.getNext();

DLNodesecond = first.getNext();

Objectobj = first.getElem();

header.setNext(second);

second.setPrev(header);

size--;

return(obj);

//删除末节点

public Object removeLast() throws ExceptionQueueEmpty {

DLNodefirst = trailer.getPrev();

DLNodesecond = first.getPrev();

trailer.setPrev(second);

second.setNext(trailer);

//遍历

public void Traversal() {

DLNodep = header.getNext();

while (p != trailer) {

System.out.print(p.getElem()+" ");

p = p.getNext();

System.out.println();

用JAVA语言解决:编写一个链表类(双向链表),实现插入,删除,查找操作

public class DoubleLinkedList

{

// 节点类Node

private static class Node

Object value;

Node prev = this;

Node next = this;

Node(Object v)

value = v;

public String toString()

return value.toString();

private Node head = new Node(null); // 头节点

private int size; // 链表大小

// 以下是接口方法

public boolean addFirst(Object o)

addAfter(new Node(o), head);

return true;

public boolean addLast(Object o)

addBefore(new Node(o), head);

public boolean add(Object o)

return addLast(o);

public boolean add(int index, Object o)

addBefore(new Node(o), getNode(index));

public boolean remove(int index)

removeNode(getNode(index));

public boolean removeFirst()

removeNode(head.next);

public boolean removeLast()

removeNode(head.prev);

public Object get(int index)

return getNode(index).value;

public int size()

return size;

StringBuffer s = new StringBuffer("[");

Node node = head;

for (int i = 0; i size; i++)

node = node.next;

if (i 0)

s.append(", ");

s.append(node.value);

s.append("]");

return s.toString();

private Node getNode(int index)

if (index 0 || index = size)

throw new IndexOutOfBoundsException();

Node node = head.next;

for (int i = 0; i index; i++)

return node;

private void addBefore(Node newNode, Node node)

newNode.next = node;

newNode.prev = node.prev;

newNode.next.prev = newNode;

newNode.prev.next = newNode;

private void addAfter(Node newNode, Node node)

newNode.prev = node;

newNode.next = node.next;

private void removeNode(Node node)

node.prev.next = node.next;

node.next.prev = node.prev;

node.prev = null;

node.next = null;

//测试类:

public class Test

public static void main(String[] args)

DoubleLinkedList dll = new DoubleLinkedList();

//添加

dll.add("张三");

dll.add("李四");

dll.add("王五");

System.out.println(dll);

//添加到最前

dll.addFirst("孙七");

//添加到最后,同添加

dll.addLast("赵六");

//添加到指定位置

//移除最前的

dll.removeFirst();

//移除最后的

dll.removeLast();

//移除指定位置上的

//返回指定位置上的元素

System.out.println(dll.get(1));

java双向链表

public boolean putAfter(Object obj,DoublyListNode node)//有可能找不到obj,所以我返回boolean

DoublyListNode current = head;

while(head.obj!=obj){

current = current.next;

if(current==null)

双向链表查找代码java-图3

return false;

if(current==tail){

tail = node;

}else{

node.next = current.next;

current.next.previous = node;

node.previous = current;

current.next =node;

public DoublyListNode removeafter(Object obj){//返回了选中的节点

while(current.obj!=obj)

if(current == null)

return null;

if(current==head)

head = current.next;

else

current.previous.next = current.next;

if(current == tail)

tail = current.previous;

current.next.previous = current.previous;

return current;

在Java中如何实现双向链表

双向链表:就是有双向指针,即双向的链域.

链结点的结构:

┌────┬────┬────────┐

│ data │ next │ previous │

└────┴────┴────────┘

双向链表不必是双端链表(持有对最后一个链结点的引用),双端链表插入时是双向的.

有两条链:一条从头到尾,一条从尾到头,删除遍历时也是双向的.

/**

* 双向链表

public class DoublyLinkedListt {

private Linkt head; //首结点

private Linkt rear; //尾部指针

public DoublyLinkedList() { }

public T peekHead() {

if (head != null) {

return head.data;

public boolean isEmpty() {

return head == null;

public void insertFirst(T data) {// 插入 到 链头

Linkt newLink = new Linkt(data);

if (isEmpty()) {//为空时,第1次插入的新结点为尾结点

rear = newLink;

} else {

head.previous = newLink; //旧头结点的上结点等于新结点

newLink.next = head; //新结点的下结点旧头结点

head = newLink; //赋值后,头结点的下结点是旧头结点,上结点null

public void insertLast(T data) {//在链尾 插入

if (isEmpty()) {

head = newLink;

rear.next = newLink;

newLink.previous = rear;

rear = newLink; //赋值后,尾结点的上结点是旧尾结点,下结点null

public T deleteHead() {//删除 链头

if (isEmpty()) return null;

Linkt temp = head;

head = head.next; //变更首结点,为下一结点

head.previous = null;

rear = null;

return temp.data;

public T deleteRear() {//删除 链尾

Linkt temp = rear;

rear = rear.previous; //变更尾结点,为上一结点

if (rear != null) {

rear.next = null;

head = null;

public T find(T t) {//从头到尾find

Linkt find = head;

while (find != null) {

if (!find.data.equals(t)) {

find = find.next;

break;

if (find == null) {

return find.data;

public T delete(T t) {

Linkt current = head;

while (!current.data.equals(t)) {

if (current == null) {

if (current == head) {

head = head.next;

} else if (current == rear) {

rear = rear.previous;

//中间的非两端的结点,要移除current

return current.data;

public boolean insertAfter(T key, T data) {//插入在key之后, key不存在return false

while (!current.data.equals(key)) {

if (current == rear) {

newLink.next = current.next;

current.next.previous = newLink;

current.next = newLink;

newLink.previous = current;

System.out.println("List (first--last):");

while (current != null) {

System.out.println("List (last--first):");

Linkt current = rear;

current = current.previous;

class Linkt {//链结点

T data; //数据域

Linkt next; //后继指针,结点 链域

Linkt previous; //前驱指针,结点 链域

Link(T data) {

this.data = data;

System.out.println("the data is " + data.toString());

public static void main(String[] args) {

DoublyLinkedListinteger list = new DoublyLinkedListinteger();

list.insertLast(1);

Integer deleteHead = list.deleteHead();

System.out.println("deleteHead:" + deleteHead);

Integer deleteRear = list.deleteRear();

System.out.println("deleteRear:" + deleteRear);

System.out.println("delete find:" + list.delete(1));

System.out.println("----在指定key后插入----");

以上就是土嘎嘎小编为大家整理的双向链表查找代码java相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!

版权声明:倡导尊重与保护知识产权。未经许可,任何人不得复制、转载、或以其他方式使用本站《原创》内容,违者将追究其法律责任。本站文章内容,部分图片来源于网络,如有侵权,请联系我们修改或者删除处理。

编辑推荐

热门文章