Java实现顺序表算法:
1:首先我们需要定义我们的接口,关于顺序表的一些基本的操作:顺序表中的操作都有增删改查。
//List接口
public interface IList {
//返回线性表的大小,即数据元素的个数。
public int getSize();
//如果线性表为空返回 true,否则返回 false。
public boolean isEmpty();
//判断线性表是否包含数据元素 e
public boolean contains(Object e);
//返回数据元素 e 在线性表中的序号
public int indexOf(Object e);
//将数据元素 e 插入到线性表中 i 号位置
public void insert(int i, Object e) throws OutOfBoundaryException;
//将数据元素 e 插入到元素 obj 之前
public boolean insertBefore(Object obj, Object e);
//将数据元素 e 插入到元素 obj 之后
public boolean insertAfter(Object obj, Object e);
//删除线性表中序号为 i 的元素,并返回之
public Object remove(int i) throws OutOfBoundaryException;
//删除线性表中第一个与 e 相同的元素
public boolean remove(Object e);
//替换线性表中序号为 i 的数据元素为 e,返回原数据元素
public Object replace(int i, Object e) throws OutOfBoundaryException;
//返回线性表中序号为 i 的数据元素
public Object get(int i) throws OutOfBoundaryException;
}

2.我们在这里还需要比较元素的大小,我们就写一个比较元素大小的策略的接口。

//对象比较策略接口
public interface IStrategy {
//判断两个数据元素是否相等
public boolean equal(Object obj1, Object obj2);
/**
* 比较两个数据元素的大小 * 如果 obj1 < obj2 返回-1
* 如果obj1 = obj2 返回0
* 如果obj1 > obj2 返回1
*/
public int compare(Object obj1, Object obj2);
}

3.写我们这里需要的策略的实现。

/**
* 默认比较策略类
*/
public class DefaultStrategy implements IStrategy { @Override
public boolean equal(Object obj1, Object obj2) {
return obj1.equals(obj2);
} @Override
public int compare(Object obj1, Object obj2) {
return obj1.toString().compareTo(obj2.toString());
} }

4.我们策略已经写完,下一步我们就写我们顺序表的实现。

//顺序表类
public class MyArrayList implements IList{ public static void main(String[] args) {
// TODO Auto-generated method stub }
private final int LEN = 8; //数组的默认大小
private IStrategy strategy; //数据元素比较策略
private int size; //线性表中数据元素的个数
private Object[] elements; //数据元素数组
//构造方法
public MyArrayList(){
this(new DefaultStrategy());
} public MyArrayList(IStrategy strategy){
this.strategy = strategy;
size = 0;
elements = new Object[LEN];
}
@Override
public int getSize() {
// TODO Auto-generated method stub
return this.size;
} @Override
public boolean isEmpty() {
// TODO Auto-generated method stub
return size == 0;
} @Override
public boolean contains(Object e) {
// TODO Auto-generated method stub
for(int i = 0; i < size; i++){
if(this.strategy.equal(e, elements[i])){
return true;
}
}
return false;
} @Override
public int indexOf(Object e) {
// TODO Auto-generated method stub
for( int i = 0; i < size; i++){
if(strategy.equal(e, elements[i])){
return i;
}
}
return -1;
} @Override
public void insert(int i, Object e) throws OutOfBoundaryException {
// TODO Auto-generated method stub
//检查下标越界
if( i < 0 || i >= size){
throw new OutOfBoundaryException("指定的插入序号越界。");
}
//检查线性表数组的容量
if (size >= elements.length){
expandSpace();
}
//将插入位置后的数据元素依次向后移动一个单位
for( int j = size; j > i; j--){
elements[j] = elements[j-1];
}
//插入数据
elements[i] = e;
size++; //元素个数加1
}
//扩展顺序表空间
private void expandSpace(){
Object[] a = new Object[elements.length*2];
for (int i=0; i<elements.length; i++) {
a[i] = elements[i];
}
elements = a;
}
@Override
public boolean insertBefore(Object obj, Object e) {
// TODO Auto-generated method stub
//找到插入位置
int i = indexOf(obj);
if (i<0) {
return false;
}
insert(i,e);
return true;
} @Override
public boolean insertAfter(Object obj, Object e) {
// TODO Auto-generated method stub
int i = indexOf(obj);
if (i<0) {
return false;
}
insert(i+1,e);
return true;
} @Override
public Object remove(int i) throws OutOfBoundaryException {
// TODO Auto-generated method stub
//首先检查越界
if (i<0||i>=size) {
throw new OutOfBoundaryException("错误,指定的删除序号越界。");
}
Object obj = elements[i];
//被删除的数据元素后的数据前移一个单位
for (int j=i; j<size-1; j++) {
elements[j] = elements[j+1];
}
//
elements[--size] = null;
return obj;
} @Override
public boolean remove(Object e) {
// TODO Auto-generated method stub
//找到被删除数据元素的位置
int i = indexOf(e);
if (i<0) {
return false;
}
remove(i);
return true;
} @Override
public Object replace(int i, Object e) throws OutOfBoundaryException {
// TODO Auto-generated method stub
if (i<0||i>=size){
throw new OutOfBoundaryException("错误,指定的序号越界。");
}
Object obj = elements[i];
elements[i] = e;
return obj;
} @Override
public Object get(int i) throws OutOfBoundaryException {
// TODO Auto-generated method stub
if (i<0||i>=size){
throw new OutOfBoundaryException("错误,指定的序号越界。");
}
return elements[i];
} }

5.上面的代码中我们的函数都抛出了一个异常,这个异常是我们自己定义的。

public class OutOfBoundaryException extends RuntimeException{

    public OutOfBoundaryException(String err){
super(err);
}
}

数据结构顺序表Java实现的更多相关文章

  1. 顺序表----java实现

    最简单的数据结构--顺序表,此处以数组为例. 顺序表的优点:支持随机读取,内存空间利用率高. 顺序表的缺点:1.需要预先给出最大数据元素个数,这往往很难实现. 2.插入和删除时需要移动大量数据. Se ...

  2. hrbustoj 1545:基础数据结构——顺序表(2)(数据结构,顺序表的实现及基本操作,入门题)

    基础数据结构——顺序表(2) Time Limit: 1000 MS    Memory Limit: 10240 K Total Submit: 355(143 users) Total Accep ...

  3. hrbust-1545-基础数据结构——顺序表(2)

    http://acm.hrbust.edu.cn/index.php?m=ProblemSet&a=showProblem&problem_id=1545 基础数据结构——顺序表(2) ...

  4. Java数据结构——顺序表

    一个线性表是由n(n≥0)个数据元素所构成的有限序列. 线性表逻辑地表示为:(a0,a1,…,an-1).其中,n为线性表的长度,n=0时为空表.i为ai在线性表中的位序号. 存储结构:1.顺序存储, ...

  5. c数据结构 顺序表和链表 相关操作

    编译器:vs2013 内容: #include "stdafx.h"#include<stdio.h>#include<malloc.h>#include& ...

  6. 数据结构顺序表删除所有特定元素x

    顺序表类定义: template<class T> class SeqList : { public: SeqList(int mSize); ~SeqList() { delete[] ...

  7. 数据结构---顺序表(C++)

    顺序表 是用一段地址连续的存储单元依次存储线性表的数据元素. 通常用一维数组来实现 基本操作: 初始化 销毁 求长 按位查找 按值查找 插入元素 删除位置i的元素 判空操作 遍历操作 示例代码: // ...

  8. 顺序表JAVA代码

        publicclassSeqList{       final int defaultSize =10;     //默认的顺序表的最大长度     int maxSize;          ...

  9. python算法与数据结构-顺序表(37)

    1.顺序表介绍 顺序表是最简单的一种线性结构,逻辑上相邻的数据在计算机内的存储位置也是相邻的,可以快速定位第几个元素,中间不允许有空,所以插入.删除时需要移动大量元素.顺序表可以分配一段连续的存储空间 ...

随机推荐

  1. Effective C++ Item 33 Avoid hiding inherited names

    class Base { private: int x; public: ; virtual void mf2(); void mf3(); ... }; class Derived: public ...

  2. C++11新特性之二——std::bind std::function 高级用法

    /* * File: main.cpp * Author: Vicky.H * Email: eclipser@163.com */ #include <iostream> #includ ...

  3. android基础---->AIDL服务的使用

    AIDL和其他的IDL类似,它允许你定义程序接口,以便客户端与服务器端通过IPC机制交互.在android上面,一个进程一般不能访问另外进程的内存.因此,Android平台将这些跨进程访问的对象分解成 ...

  4. 【CSS系列】对表单和数据表格应用样式

    表格特有的元素: 1.summary和caption caption用作与表格的标题.summary应用于表格标签,用来描述表格的内容,于image标签的alt文本相似. 2.thead tbody ...

  5. 使用Java对文件进行解压缩

    最近在一个项目中需要对文件进行自动的解压缩,Java提供了这种支持,还是挺好用的. 工具包封装在java.util.zip中. 1.首先是多个文件压缩成一个ZIP文件 思路:用一个ZipOutputS ...

  6. ubuntu 创建桌面快捷方式

    $sudo apt-get install gnome-panel $gnome-desktop-item-edit  /home/xxx/桌面 --create-new 命令行:填入程序名称,如/u ...

  7. Android 7.1 SystemUI--任务管理--场景一:长按某个缩略图,拖动分屏的流程

    TaskView 类的长按事件 onLongClick 方法内发送了 DragStartEvent 事件消息,该 DragStartEvent 事件消息由 RecentsView,TaskStackV ...

  8. 摄像头的管理(camera) ---- HTML5+

    模块:camera Camera模块管理设备的摄像头,可用于拍照.摄像操作,通过plus.camera获取摄像头管理对象. 应用场景:保存自拍,保存照片,上传照片,保存视频,上传视频: 通过之前的模块 ...

  9. etc/fstab

    etc/fstab 就是在开机引导的时候自动挂载到linux的文件系统 设备名称 挂载点 分区的类型 挂载选项 dump选项 fsck选项UUID=ce25cdc7-434f-420b-b3 / ex ...

  10. Fiddler关闭自动更新

    1,fiddler 启动时老弹出要更新,但不想更新,可以这样设置 Tools-Optons->General 把第一个√去掉