线性表

         线性表是其组成元素具有线性关系的一种线性结构,对线性表的基本操作主要有获得元素值、设置元素值、插入、删除、查找、替换和排序等,插入和删除操作可以在线性表的 任意位置进行。

       线性表有顺序表和链表两种。顺序表存储方式是在内存开辟一组连续的空间存放数据元素,元素的内存物理存储次序和它们在线性表中的逻辑次序相同。链表的存储方式是用若干地址分散的存储单元存储数据元素,逻辑上相邻的两个元素在内存中的物理位置不一定相同。所以,在链表中每个节点都有下一个节点的信息。

      下面是两种不同的实现方式:

       定义一个公共的线性表接口,顺序表和链表都实现此接口,

      public interface LList<T> {
     boolean isEmpty();
     int length();
     T get(int i);
     void set(int i,T x);
     void insert(int i,T x);
     void append(T x);
     T remove(int i);
     void removeAll();
   }

顺序表:

public class SeqList<T> implements LList<T> {
    private Object[] element;
private int len;
    public SeqList(int size){
    this.element = new Object[size];
    this.len = 0;
    }
    public SeqList(){this(64);}
@Override
public boolean isEmpty() {
// TODO Auto-generated method stub
return this.len == 0;
}


@Override
public int length() {
// TODO Auto-generated method stub
return this.len;
}


@Override
public T get(int i) {
// TODO Auto-generated method stub
if(i >= 0 && i < len){
return (T)this.element[i];
}
return null;
}


@Override
public void set(int i, T x) {
// TODO Auto-generated method stub
if(x == null){
return;
}
if(i >= 0 && i < len){
this.element[i] = x;
}else
throw new IndexOutOfBoundsException(i + "");
}


@Override
public void insert(int i, T x) {
// TODO Auto-generated method stub
if(x == null){
return;
}
if(this.len == element.length){
Object[] temp = this.element;
Object[] element = new Object[temp.length * 2];
for(int j = 0;j < temp.length;j ++){
this.element[j] = temp[j];
}
}
if(i < 0)
i = 0;
if(i > this.len)
i = this.len;
for(int j = this.len;j > i;j --){
this.element[j] = this.element[j-1];
}
this.element[i] = x;
this.len ++;
}


@Override
public void append(T x) {
// TODO Auto-generated method stub
   insert(this.len,x);
}


@Override
public T remove(int i) {
// TODO Auto-generated method stub
if(i >= 0 && i < len){
T temp = (T)element[i];
for(int j = i;j < len - 1;j ++){
element[j] = element[j+1];
}
element[this.len-1] = null;
this.len --;
return temp;
}
return null;
}


@Override
public void removeAll() {
// TODO Auto-generated method stub
this.len = 0;
}


public String toString(){
    String str="(";
    if(this.len > 0)
    str += this.element[0].toString();
    for(int i = 1;i < this.len;i ++)
    str += this.element[i].toString();
    return str += ")";
    }
    //比较两个顺序表是否相等
    public boolean equals(Object obj){
    if(obj == null)
    return false;
    if(obj instanceof SeqList){
    SeqList<T> list = (SeqList<T>)obj;
    if(this.length() == list.length()){
    for(int i = 0;i <this.length();i ++){
    if(!(this.get(i)).equals(list.get(i)))
    return false;
    }
    return true;
    }
    }
    return false;
    }
}

链表:

public class LinkedList<T> implements LList<T> {
    public Node<T> head;
public LinkedList(){
    this.head = new Node<T>();
    }
public LinkedList(T[] element){
this();
Node<T> rear = this.head;
for(int i = 0;i < element.length;i ++){
rear.next = new Node<T>(element[i],null);
rear = rear.next;
}
}
@Override
public boolean isEmpty() {
// TODO Auto-generated method stub
return this.head.next == null;
}


@Override
public int length() {
// TODO Auto-generated method stub
int i = 0;
Node<T> p = this.head.next;
while(p != null){
p = p.next;
i++;
}
return i;
}


@Override
public T get(int i) {
// TODO Auto-generated method stub
if(i >= 0){
Node<T> p = this.head.next;
             for(int j = 0;p != null && j <i;j ++){
            p = p.next;
             }
             if(p != null)
            return p.date;
}
return null;
}


@Override
public void set(int i, T x) {
// TODO Auto-generated method stub
if(x == null)
return;
if(i >= 0){
Node<T> p = this.head.next;
for(int j = 0;p != null && j < i;j ++){
p = p.next;
}
if(p != null)
p.date = x;
}else
throw new IndexOutOfBoundsException(i + "");
}


@Override
public void insert(int i, T x) {
// TODO Auto-generated method stub
if(x == null)
return;
Node<T> p = this.head;
for(int j = 0;p.next != null && j < i;j ++)
p = p.next;
   p.next = new Node<T>(x,p.next);
}


@Override
public void append(T x) {
// TODO Auto-generated method stub
insert(Integer.MAX_VALUE,x);
}


@Override
public T remove(int i) {
// TODO Auto-generated method stub
if(i >= 0){
Node<T> p = this.head;
for(int j = 0;p.next != null && j < i;j ++)
p = p.next;
if(p.next != null){
T old = p.next.date;
p.next = p.next.next;
return old;
}
}
return null;
}


@Override
public void removeAll() {
// TODO Auto-generated method stub
this.head.next = null;
}


public boolean equals(Object obj){
if(obj == this)
return true;
if(!(obj instanceof LinkedList)) 
return false;
Node<T> p = this.head.next;
Node<T> q = ((LinkedList<T>)obj).head.next;
while(p != null && q != null && p.date.equals(q.date)){
p = p.next;
q = q.next;
}
return p == null && q == null;
}

public String toString(){
String str = "(";
Node<T> p = this.head.next;
while(p != null){
str += p.date.toString();
if(p.next != null)
str += ",";
p = p.next;
}
return str + ")";
}
}
class Node<T>{
public T date;
public Node<T> next;
public Node(T date,Node<T> next){
this.date = date;
this.next = next;
}
public Node(){this(null,null);}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值