java——线性表接口实现
线性表是存储顺序牌类的数据时最常用的数据结构。
实现线性表有两种方式。第一种是使用数组存储线性表的元素。数组是动态创建的。超过数组的容量时,创建一个
新的更大的数组,并且将当前数组中的元素复制到新建的数组中。另一种方法是用链表结构实现。链表由节点组成,每
个结点都是动态生成的,用来存储一个元素。所有的结点连接成一个线性表。
对于线性表的主要操作有:
1、提取线性表的元素
2、在线性表中插入一个新元素
3、从线性表中删除一个元素
4、获取线性表中元素的个数
5、查找线性表中是否包含某个元素
6、判断线性表是否为空
下面这个接口类定义了常用的操作。
package com.ezreal;
public interface ListIntf {
/**
* 返回表长度
* @return
*/
public int size();
/**
* 增加元素
* @param obj
*/
public void add(Object obj);
/**
* 重置为空表
*/
public void clear();
/**
* 判断是否为空
* @return
*/
public boolean isEmpty();
/**
* 第i个数据元素的值
* @param i
* @return
*/
public Object get(int i);
/**
* 返回第一个这个元素的位置
* @param obj
* @return
*/
public int indexOf(Object obj);
/**
* 返回这个元素的前驱
* @param obj
* @return
*/
public Object getPre(Object obj);
/**
* 返回这个元素的后继
* @param obj
* @return
*/
public Object getNext(Object obj);
/**
* 第i个位置插入新的元素对象
* @param obj
* @param i
*/
public void insertElementAt(Object obj ,int i);
/**
* 删除第i个元素
* @param i
* @return
*/
public Object remove(int i);
/**
* 删除数据元素obj,并返回这个元素的值
* @param obj
* @return
*/
public Object remove(Object obj);
}
接下来用数组实现线性表。数组的类型是Object类型,所以,数组中每个元素实际元素存储的是对象的。
package com.ezreal;
public class SqList implements ListIntf {
final int maxlen = 1000;
Object v[] = new Object[maxlen];
int len = 0;
public SqList() {
}
@Override
public void add(Object obj) {
if(len == maxlen){
System.out.println("溢出");
}else{
v[len] = obj;
len++;
}
}
@Override
public int size() {
return len;
}
@Override
public void clear() {
len =0;
}
@Override
public boolean isEmpty() {
if(len == 0){
return true;
}
return false;
}
@Override
public Object get(int i) {
if(i<1 || i>len){
System.out.println("获取元素位置不正确");
}else{
return v[i-1];
}
return null;
}
@Override
public int indexOf(Object obj) {
for(int i=0;i<len;i++){
if(v[i].equals(obj)){
return i;
}
}
return -1;
}
@Override
public Object getPre(Object obj) {
int i = indexOf(obj);
if(i==-1){
System.out.println("无该元素");
}else if(i == 0){
System.out.println("无前驱");
}else{
return v[i-1];
}
return null;
}
@Override
public Object getNext(Object obj) {
int i = indexOf(obj);
if(i==-1){
System.out.println("无该元素");
}else if(i == len){
System.out.println("无前驱");
}else{
return v[i+1];
}
return null;
}
@Override
public void insertElementAt(Object obj, int i) {
if(len == maxlen){
System.out.println("溢出");
return;
}else {
if(i < 0 || i >len){
System.out.println("插入位置不正确");
return;
}else{
for(int j=len-1;j>=i-1;j--){
v[j+1]=v[j];//第i个元素和他后面的所有元素均后移一个位置
}
v[i-1]=obj;
len++;
return;
}
}
}
@Override
public Object remove(int i) {
Object obj;
if(i<1 || i>len){
System.out.println("删除位置不正确");
}else{
obj = v[i-1];
for(int j=i;j<len;j++){
v[j-1]=v[j];
}
len--;
return obj;
}
return null;
}
@Override
public Object remove(Object obj) {
int i=indexOf(obj);
if(i==-1){
System.out.println("无该元素");
}else {
remove(i+1);
}
return null;
}
}
如有不对的地方,请各位看官指出。
java——线性表接口实现的更多相关文章
- Java线性表的排序
Java线性表的排序 ——@梁WP 前言:刚才在弄JDBC的时候,忽然觉得order-by用太多了没新鲜感,我的第六感告诉我java有对线性表排序的封装,然后在eclipse里随便按了一下“.” ,哈 ...
- 线性表接口的实现_Java
线性表是其组成元素间具有线性关系的一种线性结构,对线性表的基本操作主要有插入.删除.查找.替换等,这些操作可以在线性表的任何位置进行.线性表可以采用顺序存储结构和链式存储结构表示. 本接口的类属于da ...
- Java 线性表、栈、队列和优先队列
1.集合 2.迭代器 例子: 3.线性表 List接口继承自Collection接口,有两个具体的类ArrayList或者LinkedList来创建一个线性表 数组线性表ArrayList Linke ...
- java线性表学习笔记(一)
线性表是一种按顺序储存数据是的常用结构,大多数的线性表都支持以下的典型操作: 从线性表提取插入删除一个数据: 找出线性表中的某一个元素: 找出线性表中的元素: 确定线性表中是否包含某一个元素,确定线性 ...
- 数据结构与算法分析java——线性表1
说到线性结构的话,我们可以根据其实现方式分为三类: 1)顺序结构的线性表 2)链式结构的线性表 3)栈和队列的线性表 应用程序后在那个的数据大致有四种基本的逻辑结构: 集合:数据元素之间只有&qu ...
- java线性表之顺序表实现
仿照arrayList写了一个简化版的线性表,主要为了用来研究arrayList在实现什么操作的情况下比较节省性能,楼主文采很差,直接上代码. import java.util.Arrays; pub ...
- 数据结构与算法分析java——线性表3 (LinkedList)
1. LinkedList简介 LinkedList 是一个继承于AbstractSequentialList的双向链表.它也可以被当作堆栈.队列或双端队列进行操作.LinkedList 实现 Lis ...
- 数据结构与算法分析java——线性表2(ArrarList )
ArrayList ArrayList 是一个数组队列,相当于 动态数组.与Java中的数组相比,它的容量能动态增长.它继承于AbstractList,实现了List, RandomAccess, C ...
- java线性表学习笔记(二)
链表中的每一个元素都包含一个称为节点的结构,每向链表中增加一个元素,就会产生一个与之相关的节点,每个节点与它相邻的节点相连接(这是基础吧,不过在看c的时候没认真看,呼). 定义节点类如下(使用了泛型, ...
随机推荐
- Git最常用的命令 总结
stage/unstage git add xxx.xx 和 git reset HEAD xxx.xx 前者将本地的修改提交到index(此操作成为stage,参考备注1),后者将已提交到inde ...
- 20155212 实验二 Java面向对象程序设计
20155212 实验二 Java面向对象程序设计 单元测试 三种代码 用编程去解决问题,必须学会写三种码: 伪代码 产品代码 测试代码 例: MyUtil 类解决一个百分制成绩转成"优.良 ...
- C语言复习20170821
函数 函数头部参数表里的变量称为形参,也是内部变量,只能在函数体内访问. 形参的作用是实现主调函数与被调函数之间的联系,通常将函数所处理的数据,影响函数功能的因素或者函数处理的结果作为形参.没有形参的 ...
- 2016-2017-2 20155331 实验二《Java面向对象程序设计》实验报告
2016-2017-2 20155331 实验二<Java面向对象程序设计>实验报告 实验内容 1.初步掌握单元测试和TDD 2.理解并掌握面向对象三要素:封装.继承.多态 3.初步掌握U ...
- QStackedWidget 与 QStackedLayout 的用法区别
import sys from PyQt5 import QtWidgets, QtCore class MyWidget(QtWidgets.QWidget): def __init__(self, ...
- 使用WinIO库实现保护模式下的IO和内存读写
问题已解决: 原因是函数的调用方式与WinIO中不一致,使用的时候漏掉了__stdcall. 函数原定义为: 在实际的GPIO读写中遇到以下问题: SetPortVal可正常写入,但是GetPortV ...
- SaltStack入门篇(五)之salt-ssh的使用以及LAMP状态设计部署
1.salt-ssh的使用 官方文档:https://docs.saltstack.com/en/2016.11/topics/ssh/index.html ()安装salt-ssh [root@li ...
- springboot 中根据数据库表生成所有表的model,mapper和xml文件
参考文件:https://blog.csdn.net/shenmoren6/article/details/80337662?utm_source=blogxgwz1 详细信息:https://blo ...
- [cogs2314][HZOI 2015] Persistable Editor - 可持久化平衡树
[cogs2314][HZOI 2015]Persistable Editor - 可持久化平衡树 题目链接 首先吐槽扯淡几句 [题目描述] 维护一种可持久化的文本编辑器,支持下列操作: 1 p st ...
- linux设置定时任务调用接口
1.设置目录 cd /var/spool/cron 2.编辑文件(当前登录用户,不一定是root) vim root 3.添加内容 0 0 * * * wget http://192.144.141. ...