双向循环链表

<p><span style="font-size:32px;"><strong style="background-color: rgb(153, 153, 255);">双向循环链表</strong></span></p><p>1、每个节点的next域构成了一个循环单链表</p><p>2、每个节点的prev域构成了另一个循环单链表</p><p><span style="font-size:32px;color:#ff0000;">add</span></p><img src="" width="400" height="200" alt="" />
package exp1;

import java.util.Scanner;

class TwoWayLinkedListNode<AnyType> {
	AnyType data;
	TwoWayLinkedListNode<AnyType> pre;
	TwoWayLinkedListNode<AnyType> next;
	public TwoWayLinkedListNode(AnyType data){
		this.data=data;
		this.pre=null;
		this.next=null;
	}
	public TwoWayLinkedListNode(AnyType data,TwoWayLinkedListNode<AnyType> pre){
		this.data=data;
		this.pre=pre;
		this.next=null;
	}
	public TwoWayLinkedListNode(AnyType data,TwoWayLinkedListNode<AnyType> pre,TwoWayLinkedListNode<AnyType> next){
		this.data=data;
		this.pre=pre;
		this.next=next;
	}
public class TwoWayLinkedList<AnyType> {
	public TwoWayLinkedListNode firstNode;
	public TwoWayLinkedListNode lastNode;
	public TwoWayLinkedList(){
		firstNode=null;
	}
	public boolean insertNode(int idx,AnyType data){
		if(idx==1){
			insertFirstNode(data);
			return true;
		}
		else{
			TwoWayLinkedListNode <AnyType>p=firstNode;
			int j=0;
			for(j=0;j<idx-1&&p!=null;j++){
				p=p.next;
			}
			if(j==idx-1){
				TwoWayLinkedListNode<AnyType> q=p.pre;
				TwoWayLinkedListNode<AnyType> tmp=new TwoWayLinkedListNode(data,null,null);
				q.next=tmp;
				tmp.pre=q;
				tmp.next=p;
				p.pre=tmp;
				return true;
			}
			else{
				System.out.println("插入超过范围");
				return false;
			}
		}
	}
	public void add(AnyType data){
		TwoWayLinkedListNode<AnyType> p=firstNode;
		if(p==null){
			TwoWayLinkedListNode<AnyType> tmp=new TwoWayLinkedListNode<AnyType>(data,null,null);
			tmp.pre=tmp;
			tmp.next=tmp;
			firstNode=tmp;
		}
		else{
			insertLastNode(data);
		}
	}
	public void insertFirstNode(AnyType data){
		TwoWayLinkedListNode<AnyType> p=firstNode;
		TwoWayLinkedListNode<AnyType> tmp=new TwoWayLinkedListNode<AnyType>(data,p.pre,p);
		p.pre.next=tmp;
		p.pre=tmp;
		firstNode=tmp;
	}
	public void insertLastNode(AnyType data){
		TwoWayLinkedListNode<AnyType> p=firstNode;
		TwoWayLinkedListNode<AnyType> q=p.pre;
		TwoWayLinkedListNode<AnyType> tmp=new TwoWayLinkedListNode(data,q,p);
		q.next=tmp;
		p.pre=tmp;
	}
	public boolean deleteNode(int idx){
		if(idx==1){
			TwoWayLinkedListNode<AnyType> p=firstNode;
			p.pre.next=p.next;
			p.next.pre=p.pre;
			firstNode=p.next;
			return true;
		}
		else{
			TwoWayLinkedListNode<AnyType> p=firstNode;
			int j=0;
			for(j=0;j<idx-1&&p!=null;j++){
				p=p.next;
			}
			if(j==idx-1){
				p.next=p.next.next;
				p.next.pre=p;
				return true;
			}
			else{
				System.out.println("删除的元素不存在");
				return false;
			}
			}
		}

public void print(){
	TwoWayLinkedListNode<AnyType> p=firstNode;
	System.out.print(p.data+" ");
	p=p.next;
	while(p!=firstNode){
		System.out.print(p.data+" ");
		p=p.next;
	}
	System.out.println();
}
public void reverse(){  
    TwoWayLinkedListNode p=firstNode;
    while(p.next!=firstNode){  
        TwoWayLinkedListNode q=p;  
        TwoWayLinkedListNode r=p.next;  
        q.next=q.pre;  
        q.pre=r;  
        p=p.pre;  
    }  
    TwoWayLinkedListNode q=p;  
    TwoWayLinkedListNode r=p.next;  
    q.next=q.pre;  
    q.pre=r;  
    TwoWayLinkedListNode s=firstNode;  
    firstNode=lastNode;  
    lastNode=s;  
      
    int i=0;  
    for(TwoWayLinkedListNode x=firstNode.next;x!=lastNode;x=x.next){  
        System.out.println(i+": "+x.data);  
        i++;  
    }  
    i=0;  
}  
public void main(String args[]){
	TwoWayLinkedList<Integer> my=new TwoWayLinkedList();
	int len,a;
	System.out.println("请输入链表的长度:");
	Scanner cin=new Scanner(System.in);
	len=cin.nextInt();
	System.out.println("请输入链表的各个点:");
	for(int i=0;i<len;i++){
		a=cin.nextInt();
		my.add(a);
	}
	int pos,val;
	System.out.println("请输入要插入的点的位置和值:");
	pos=cin.nextInt();
	val=cin.nextInt();
	my.insertNode(pos+1,val);
	System.out.println("链表的顺序是:");
	my.print();
	System.out.println("请输入要删除的位置:");
	pos=cin.nextInt();
	System.out.println("链表的顺序是:");
	my.deleteNode(pos+1);
	my.print();
	System.out.println("请输入要插入第一个顶点的值:");
	val=cin.nextInt();
	my.insertFirstNode(val);
	System.out.println("链表的顺序是:");
	my.print();
	System.out.println("请输入要插入最后一个顶点的值:");
	val=cin.nextInt();
	my.insertLastNode(val);
	System.out.println("链表的顺序是:");
	my.print();
	System.out.println("就地逆转之后的链表的顺序是:");
	my.reverse();
	my.print();}
}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值