数据结构——链表的实现

public class LinkList<E> {
	private  class node{
		public E e;
		public node next;
		public node(E e,node next){
			this.e=e;
			this.next=next;
		}

		public node(E e){
			this(e,null);
		}

		public node(){
			this(null,null);
		}
		@Override
		public String toString() {
			return e.toString();
		}
	}
	public LinkList(){
		dummyHead = new node();
		size = 0;
	}
	private node dummyHead;
	private int size;
	//向链表的index位置插入元素E
	public void add(int index,E e){
		if(index<0||index>size){
			System.out.println(index);
			throw new IllegalArgumentException("index is illeagal.");
		}
		node prev=dummyHead;
		   for(int i=0;i<index;i++){
		   	prev=prev.next;
		   }
		 // node node=new node(e);
		  // if(prev.next==null)
		   	//node=prev.next;
		//   node.next=prev.next;
		  // prev.next=node;
		prev.next=new node(e,prev.next);
		   size++;
	}
	//向链表头插入元素e
	public void addHead(E e){
		add(0,e);
	}
	//向链表尾插入元素e
	public void addLast(E e){
		  add(size,e);
	}
	//删除index位置的元素e
	public void delete(int index){
		if(index<0||index>=size){
			throw new IllegalArgumentException("index is illegal.");
		}
		node prev=dummyHead;
		for(int i=0;i<index;i++){
			  prev=prev.next;
		}
		node ret=prev.next;
		prev.next=prev.next.next;
         ret.next=null;
	}
	//查找链表中是否含有元素e
	public boolean contains(E e){
		node prev=dummyHead;
		for(int i=0;i<size;i++){
			prev=prev.next;
			if(prev.e.equals(e))
				return true;
		}
		return false;
	}
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值