博客
关于我
线型表的顺序存储结构----顺序表(学习笔记)
阅读量:489 次
发布时间:2019-03-07

本文共 1816 字,大约阅读时间需要 6 分钟。

定义一长度为80的链表,表中元素从1-80,实现对表的增、删、清0功能。

插入算法简介:

1 判断插入位置是否合理
2 把插入位置后面的元素向下移一位
3 把元素插到指定位置
4 链表长度加1

删除算法简介:

1 判断删除位置是否合理
2 把删除位置后面的元素向上移一位
3 链表长度减1

查找算法简介:

1 用for循环和equals()方法判断目标值与数组元素是否相等
2 如果相等返回一个数组元素的索引值

实现代码如下:

ListIntf接口

public interface ListIntf {   public int size();  //获取链表长度public void clear();  //清空链表public boolean isEmpty(); //判断是否为空表public Object get(int i); //获取i位置的元素public int indexOf(Object obj); //获取元素的索引位置public Object getPre(Object obj);// 获取前驱元素public Object getNext(Object obj);//获取后驱元素public void insertElementAt(Object obj,int i);//插入元素public Object remove(int i);//移除元素public Object remove(Object obj);//移除元素}

继承ListIntf接口的Sqlist程序:

public class Sqlist implements ListIntf{   	final int maxlen=100;	int len=80;	int num[]=new int[100];		public Sqlist() {      //构造方法		for(int i=0;i
len) { System.out.println("插入位置不对"); }else { for(int j=len;i
len) { System.out.println("插入位置不对"); }else { for(int j=i-1;j

运行结果:

数值是16的索引值是16--------------我是分割线-----------索引16位置前驱元素是15--------------我是分割线-----------索引16位置后驱元素是17--------------我是分割线-----------索引16位置的元素是17--------------我是分割线-----------在80索引处插入81,链表为123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081--------------我是分割线-----------移除索引1的值,链表为23456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081--------------我是分割线-----------移除数值是81的值,链表为234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980--------------我是分割线-----------清空表:0000000000000000000000000000000000000000000000000000000000000000000000000000000

转载地址:http://uhwcz.baihongyu.com/

你可能感兴趣的文章
Navicate for mysql 数据库设计-数据库分析
查看>>
Navicat下载和破解以及使用
查看>>
Navicat中怎样将SQLServer的表复制到MySql中
查看>>
navicat创建连接 2002-can‘t connect to server on localhost(10061)且mysql服务已启动问题
查看>>
Navicat可视化界面导入SQL文件生成数据库表
查看>>
Navicat向sqlserver中插入数据时提示:当 IDENTITY_INSERT 设置为 OFF 时,不能向表中的标识列插入显式值
查看>>
Navicat因导入的sql文件中时间数据类型有参数而报错的原因(例:datetime(3))
查看>>
Navicat如何连接MySQL
查看>>
navicat导入.sql文件出错2006- MySQLserver has gone away
查看>>
Navicat导入海量Excel数据到数据库(简易介绍)
查看>>
Navicat工具Oracle数据库复制 or 备用、恢复功能(评论都在谈论需要教)
查看>>
Navicat工具中建立数据库索引
查看>>
navicat工具查看MySQL数据库_表占用容量_占用空间是多少MB---Linux工作笔记048
查看>>
navicat怎么导出和导入数据表
查看>>
Navicat怎样同步两个数据库中的表
查看>>
Navicat怎样筛选数据
查看>>
Navicat报错connection is being used
查看>>
Navicat报错:1045-Access denied for user root@localhost(using passwordYES)
查看>>
Navicat控制mysql用户权限
查看>>
navicat操作mysql中某一张表后, 读表时一直显示正在载入,卡死不动,无法操作
查看>>