数据结构(java版)学习笔记(二)——线性表之顺序表
顺序表的优点:
- 随机存取元素方便,根据定位公式容易确定表中每个元素的存储位置,所以要指定第i个结点很方便
- 简单,直观
顺序表的缺点:
- 插入和删除结点困难
- 扩展不灵活,难以确定分配的空间
- 容易造成浪费
顺序表的实现:
这里我简单说一下吧,Sqlist类实现了ListIntf接口,也就是我们上一节中所提到的接口,之后eclipse中就会提示我们复写ListIntf中的方法,我们根据顺序表的特点,逐一复写即可
详情看注释吧~
PS:所有的参数i都是序号,从1开始
import java.util.Scanner;
public class SqList implements ListIntf{
final int maxlen = 1000; //线性表中可容纳最多数据元素数目
String v[] = new String[maxlen];
int len =0;//len是长度,1开始,是位序号
/**
*
* @return 返回线性表中可容纳最多数据元素数目
*/
int getmaxlen(){
return maxlen;
}
public SqList(){
//构造方法中实现相关的接收数据操作
Scanner sc = new Scanner(System.in);
int n;
String[] a = new String[maxlen];
System.out.println("请输入需要的数据个数:");
n=sc.nextInt();
sc.close();
for(int i=0;i<n;i++){
a[i] = "a"+i;//a[0]的数值是 a0,a[1]的数值是a1,以此类推……
}
setData(a);
}
/**
* 将String数组a赋值给String数组v
* @param String数组
*/
public void setData(String[] a){
v = a;
}
@Override
public int size() {
return len;
}
@Override
public void clear() {
v = new String[maxlen];
}
@Override
public boolean isEmpty() {
return len==0;
}
@Override
public String get(int i) {
return v[i-1];
}
@Override
public int indexOf(String s) {
int i;
for(i=0;i<len;i++){
if(v[i].equals(s)){
return i+1;
}
}
System.out.println("顺序表中不存在该元素!!");
return 0;
}
@Override
public String getPre(String s) {
//当前是顺序表,是顺序存储结构,无需实现此方法
return null;
}
@Override
public String getNext(String s) {
//当前是顺序表,是顺序存储结构,无需实现此方法
return null;
}
@Override
public void insertElementAt(String s, int i) {
//首先判断顺序表是否已满,其次判断i是否合法,之后再进行插入操作
if(len==maxlen){
System.out.println("顺序表已满!");
return;//结束判断,跳出判断语句
}else{
if(i<1||i>len){
System.out.println("输入的序号不合法!");
return;
}else{
for(int j=len-1;j>=i-1;j--){
v[j+1]=v[j];
}
v[i-1] =s;
len++;
return;
}
}
}
@Override
public String remove(int i) {
String string;
if(i<1||i>len){
System.out.println("输入序号不合法!");
return null;
}else{
string = v[i-1];
for(int j=i-1;j<len;j++){
v[j-1] = v[j];
}
len--;
return string;
}
}
@Override
public String remove(String s) {
// TODO Auto-generated method stub
String string;
for(int i=0;i<len;i++){
if(v[i].equals(s)){
string = v[i];
remove(i+1);//这里的i是索引(下标),索引(下标)加1成为序号
return string;
}
}
System.err.println("当前顺序表中没有该元素");
return null;
}
}
数据结构(java版)学习笔记(二)——线性表之顺序表的更多相关文章
- Java IO学习笔记二
Java IO学习笔记二 流的概念 在程序中所有的数据都是以流的方式进行传输或保存的,程序需要数据的时候要使用输入流读取数据,而当程序需要将一些数据保存起来的时候,就要使用输出流完成. 程序中的输入输 ...
- Java IO学习笔记二:DirectByteBuffer与HeapByteBuffer
作者:Grey 原文地址:Java IO学习笔记二:DirectByteBuffer与HeapByteBuffer ByteBuffer.allocate()与ByteBuffer.allocateD ...
- java jvm学习笔记二(类装载器的体系结构)
欢迎装载请说明出处:http://blog.csdn.net/yfqnihao 在了解java虚拟机的类装载器之前,有一个概念我们是必须先知道的,就是java的沙箱,什 ...
- Android(java)学习笔记192:SQLite数据库(表)的创建 以及 SQLite数据库的升级
一.数据库的创建 1.文件的创建 //引用,如果文件不存在是不会创建的 File file = new File("haha.txt"): //输出流写数据 ...
- Java基础学习笔记二十二 网络编程
络通信协议 通过计算机网络可以使多台计算机实现连接,位于同一个网络中的计算机在进行连接和通信时需要遵守一定的规则,这就好比在道路中行驶的汽车一定要遵守交通规则一样.在计算机网络中,这些连接和通信的规则 ...
- Java基础学习笔记二十五 MySQL
MySQL 在dos中操作mysql 连接mysql命令: mysql -uroot -p密码 ,连接OK,会出现mysql> 对数据库的操作 创建一个库 create database 库名 ...
- Java基础学习笔记二十七 DBUtils和连接池
DBUtils 如果只使用JDBC进行开发,我们会发现冗余代码过多,为了简化JDBC开发,本案例我们讲采用apache commons组件一个成员:DBUtils.DBUtils就是JDBC的简化开发 ...
- Android(java)学习笔记135:SQLite数据库(表)的创建 以及 SQLite数据库的升级
一.数据库的创建 1.文件的创建 //引用,如果文件不存在是不会创建的 File file = new File("haha.txt"): //输出流写数据 ...
- Java设计模式学习笔记(二) 简单工厂模式
前言 本篇是设计模式学习笔记的其中一篇文章,如对其他模式有兴趣,可从该地址查找设计模式学习笔记汇总地址 正文开始... 1. 简介 简单工厂模式不属于GoF23中设计模式之一,但在软件开发中应用也较为 ...
- sql必知必会(第四版) 学习笔记二 视图
本书用到的几个表的建表sql语句如下: --销售产品供应商 CREATE TABLE Vendors ( vend_id varchar(20) not null, vend_name varchar ...
随机推荐
- win7下配置mysql的my.ini文件
一.环境 操作系统是win7 x64, mysql是5.6.40. 二. 怎么配置? 修改my.ini文件, 添加[client], 在下面加一行 default-character-set=utf8 ...
- KMP算法与传统字符串寻找算法
原理:KMP算法是一种模板匹配算法,它首先对模板进行便利,对于模板中与模板首字符一样和首字符进行标志-1,对于模板匹配中出现不匹配的若是第一轮检查标志为0,若不是第一轮检查标志为该元素与标志为-1的距 ...
- 字符串匹配(二)----KMP算法
什么是KMP算法: KMP算法是一种改进的字符串匹配算法,由D.E.Knuth,J.H.Morris和V.R.Pratt同时发现,因此人们称它为克努特——莫里斯——普拉特操作(简称KMP算法).KMP ...
- 感恩节活动中奖名单 i春秋喊你领礼物啦!
上周我们组织的感恩节活动,得到了小伙伴们积极踊跃的回复,看到你们这么真诚的留言,我们也是满满的感动,在众多留言中,我们选出了八位幸运用户,让我们一起恭喜获奖的小伙伴们吧. 恭喜以上8位幸运的小伙伴,我 ...
- [Swift]LeetCode93. 复原IP地址 | Restore IP Addresses
Given a string containing only digits, restore it by returning all possible valid IP address combina ...
- [Swift]LeetCode921.使括号有效的最少添加 | Minimum Add to Make Parentheses Valid
Given a string S of '(' and ')' parentheses, we add the minimum number of parentheses ( '(' or ')', ...
- [Swift]LeetCode983. 最低票价 | Minimum Cost For Tickets
In a country popular for train travel, you have planned some train travelling one year in advance. ...
- spring aspect获取抽象基类日志
在实际的项目开发过程中我们其实封装了很多的类似BaseService.BaseDao等的基类,然后在切日志的时候我们一般是指向继承改抽象基类的实现类的,这时候我们就会出现无法切出调用抽象基类方法的日志 ...
- 第2章 Java编程基础
本章重点 ·Java的基本语法形式 ·Java语言中的常量与变量 ·Java语言运算符的使用 ·Java程序的流程控制 ·Java中方法的定义与使用 ·Java中数组的定义与使用 2.1 Java的基 ...
- 我们为什么要搞长沙.NET技术社区?
我们为什么要搞长沙.NET技术社区? 感谢大家的关注,请允许我冒昧的向大家汇报长沙.NET技术社区第一次交流会的会议进展情况. 活动过程汇报 2019年2月17日,继深圳,广州,西安,成都,苏州相继成 ...