首先抽象出一个线性表抽象类(包括主要的增删操作)

public abstract class MyAbstractList<E> {
public abstract void add(E t);
public abstract void add(int index,E t);
public abstract void remove();
public abstract void remove(int index);
public abstract int getCount();
public abstract E get(int index);
public abstract String toString();
public abstract boolean contains(E e);
}

ArrayList2继承抽象类,并实现当中的全部抽象方法

public class ArrayList2<E> extends MyAbstractList<E>{
private E[] e;
private int len;
private int size; ArrayList2(){
this.size = 0;
this.len = 10;
this.e = (E[]) new Object[len];
} @Override
public void add(E t) {
// TODO Auto-generated method stub
ensureCap();
e[size] = t;
size++;
} private void ensureCap() {
// TODO Auto-generated method stub
if(getCount()>=len){
E[] temp = (E[]) new Object[len*2+1];
len = len*2+1;
for(int i=0;i<len;i++){
temp[i] = e[i];
}
}
} @Override
public void add(int index, E t) {
// TODO Auto-generated method stub
ensureCap();
for(int i=size-1;i>=index;i--){
e[i+1] = e[i];
}
e[index] = t;
size++;
} @Override
public void remove() {
// TODO Auto-generated method stub
e[size] = null;
size--;
} @Override
public void remove(int index) {
// TODO Auto-generated method stub
for(int i=index;i<size-1;i++){
e[index] = e[index+1];
}
e[size] = null;
size--;
} @Override
public E get(int index){
if(index>0 && index<size){
return e[index];
}
else return null;
} public boolean isEmpty(){
return size>0? false : true;
} @Override
public int getCount() {
// TODO Auto-generated method stub
return size;
} @Override
public String toString(){
StringBuffer sb = new StringBuffer();
sb.append("[");
for(int i=0;i<size-1;i++){
sb.append(e[i]).append(",");
}
sb.append(e[size-1]);
sb.append("]");
return sb.toString().trim();
} @Override
public boolean contains(E e1){
boolean bool = false;
for(int i=0;i<size;i++){
if(e[i] == e1){
bool = true;
}
} return bool;
} }

LinkedList2 继承抽象类,并实现方法

public class LinkedList2<E> extends MyAbstractList<E> {

	private int size;
private Node<E> head; public LinkedList2(){
this.size = 0;
head = null;
}
@Override
public void add(E t) {
// TODO Auto-generated method stub
Node<E> e = new Node<E>(t);
if(size == 0) head = e;
else{
Node temp = head;
while(temp.next!=null){
temp = temp.next;
}
temp.next = e;
size++;
}
} @Override
public void add(int index, E t) {
// TODO Auto-generated method stub
if(index == 0 || index>size) add(t);
else{
Node current = head;
Node<E> e = new Node<E>(t);
for(int i=0;i<index-1;i++){
current = current.next;
}
e.next = current.next;
current.next = e;
size++;
}
} @Override
public void remove() {
// TODO Auto-generated method stub
remove(size-1);
} @Override
public void remove(int index) {
// TODO Auto-generated method stub
if(index == 0) removeFirst();
else if(index == size) removeLast();
else if(index<0 || index>size) ;
else{
Node<E> pre = head;
for(int i=0;i<index-1;i++){
pre = pre.next;
}
Node<E> current = pre.next;
pre.next = current.next;
size--;
}
} private void removeLast() {
// TODO Auto-generated method stub
if(size == 0) ;
else{
Node<E> current = head;
for(int i=0;i<size-2;i++){
current = current.next;
}
current.next = null;
size--;
}
}
private void removeFirst() {
// TODO Auto-generated method stub
head = head.next;
}
@Override
public int getCount() {
// TODO Auto-generated method stub
return size;
} @Override
public E get(int index) {
// TODO Auto-generated method stub
Node<E> current = head;
for(int i=0;i<index-1;i++){
current = current.next;
}
return current.e;
} @Override
public String toString() {
// TODO Auto-generated method stub
StringBuffer sb = new StringBuffer();
sb.append("[");
Node<E> current = head;
for(int i=0;i<size;i++){
sb.append(current.e).append(",");
}
sb.append("]");
return sb.toString().trim();
} @Override
public boolean contains(E e) {
// TODO Auto-generated method stub
if(size == 0 ) return false;
else{
Node<E> current = head;
for(int i=0;i<size-1;i++){
if(current.e == e) return true;
current = current.next;
}
return false;
} } } /**
* 链表结点
*/
class Node<E>{
E e;
Node<E> next;
Node(){
this.next = null;
}
Node(E ee){
e = ee;
next = null;
}
}

线性表 顺序存储 链式存储 ---java实现的更多相关文章

  1. C++线性表的链式存储结构

    C++实现线性表的链式存储结构: 为了解决顺序存储不足:用线性表另外一种结构-链式存储.在顺序存储结构(数组描述)中,元素的地址是由数学公式决定的,而在链式储存结构中,元素的地址是随机分布的,每个元素 ...

  2. C 线性表的链式存储实现及插入、删除等操作示例

    一.链式存储的优势 线性表的存储可以通过顺序存储或链式存储实现,其中顺序存储基于数组实现(见本人上一篇博客),在进行插入删除等操作时,需对表内某一部分元素逐个移动,效率较低.而链式结构不依赖于地址连续 ...

  3. C++编程练习(2)----“实现简单的线性表的链式存储结构“

    单链表采用链式存储结构,用一组任意的存储单元存放线性表的元素. 对于查找操作,单链表的时间复杂度为O(n). 对于插入和删除操作,单链表在确定位置后,插入和删除时间仅为O(1). 单链表不需要分配存储 ...

  4. 数据结构-线性表的链式存储相关算法(C语言实现)

    链表的简单介绍 为什么需要线性链表 当然是为了克服顺序表的缺点,在顺序表中,做插入和删除操作时,需要大量的移动元素,导致效率下降. 线性链表的分类 按照链接方式: 按照实现角度: 线性链表的创建和简单 ...

  5. 线性表的链式存储——C语言实现

    SeqList.h #ifndef _WBM_LIST_H_ #define _WBM_LIST_H_ typedef void List; typedef void ListNode; //创建并且 ...

  6. typedef struct LNode命名结构指针(线性表的链式存储)

    一.typedef 关键字 1. 简介: typedef工具是一个高级数据特性,利用typedef可以为某一些类型自定义名称. 2. 工作原理: 例如我们定义链表的存储结构时,需要定义结点的存储数据元 ...

  7. 线性表的链式存储C语言版

    #include <stdio.h> #include <malloc.h> #define N 10 typedef struct Node { int data; stru ...

  8. 线性表的链式存储结构的实现及其应用(C/C++实现)

    存档----------- #include <iostream.h> typedef char ElemType; #include "LinkList.h" voi ...

  9. javascript实现数据结构:线性表--线性链表(链式存储结构)

    上一节中, 线性表的顺序存储结构的特点是逻辑关系上相邻的两个元素在物理位置上也相邻,因此可以随机存取表中任一元素,它的存储位置可用一个简单,直观的公式来表示.然后,另一方面来看,这个特点也造成这种存储 ...

随机推荐

  1. Linux学习之CentOS(十三)--CentOS6.4下Mysql数据库的安装与配置(转)

    原文地址:http://www.cnblogs.com/xiaoluo501395377/archive/2013/04/07/3003278.html 如果要在Linux上做j2ee开发,首先得搭建 ...

  2. PUSH MESSAGE 云控等交互类测试业务的自动化

    针对的业务: 1. PUSH消息,即由云端服务向客户端推送消息 2. MESSAG消息,即用户间消息.用户群消息和聊天室消息 上干货,框架见下图:

  3. IIS服务中五种身份验证

    转载:http://os.51cto.com/art/201005/202380.htm 作为微软最经典的Web服务之一的IIS服务有大致上五种Web身份认证方法.身份认证时保障IIS服务安全的根本, ...

  4. hybrid App h5二级页面返回的时候保持与一级页面浏览的位置一致

    最近在开发公司hybrid app的时候,需要将原本原生的配置中心模块统一变更为H5,做完之后从测试那里反馈回来这样一个问题,当滑到页面底部或中部的时候进入子页面进行设置,返回的时候页面应该定位到离开 ...

  5. JSPGen4 自学路线图

  6. 【spring cloud】【IDEA】【maven】spring cloud多模块在idea上使用maven插件打包报错:程序包XXX不存在

    >>>>spring cloud 多模块 >>>>在idea上使用maven插件打包,欲打包成jar包后 进行部署 >>>> 报 ...

  7. SpreadSheet数据导出为DataTable z

    devexpress也提供了一种将excel数据,而且可以指定区域进行转换,用起来相当灵活,本人将其解决方法分享如下(代码):          private DataTable export(Wo ...

  8. .NET:CLR via C#:Runtime Serialization

    Making a Type Serializable The SerializableAttribute custom attribute may be applied to reference ty ...

  9. [Linux] 关于Unix哲学

    reference : http://www.ruanyifeng.com/blog/2009/06/unix_philosophy.html 先讲两个很老的小故事. 第一个故事. 有一家日本最大的化 ...

  10. Leader之重

    1:合理安排每个CASE并检查每个人每天的工作进度和质量: 这会让一个庞大的工作,或者看上不可能完成的任务,变成可完成的.   2:警惕对立情绪,并寻找交接者: 永远无法控制所有成员对你或者对团队对公 ...