Java 順序表專題解讀
一 、前言
順序表常用的一種,學(xué)習(xí)并了解顯得十分重要,順序表為以后的學(xué)習(xí)打下了基石。
二、順序的定義
順序表示在計算機內(nèi)存中以數(shù)組的形式保存的線性表,在內(nèi)存中占用一組連續(xù)的存儲
單元,在此中依次存儲各個元素。

三、實現(xiàn)順序表
3.1順序表的API設(shè)計

3.2 順序表的代碼實現(xiàn)
定義一個泛型類(泛型類的好處就是可以接受任意類型)
//定義一個泛型類
public class SequenceList<T> {}
在泛型類中定義成員變量
//定義一個存儲元素的數(shù)組(先定義為泛型)
private T[] eles;
//定義一個變量表示順序表中的元素個數(shù)
private int N;
定義構(gòu)造方法,用來給成員變量初始化
//添加構(gòu)造方法,用來初始化成員變量
public SequenceList(int capacity) {//接受一個容量長度
//初始化數(shù)組
this.eles = (T[]) new Object[capacity];//創(chuàng)建的是Object類型的所以需要強轉(zhuǎn)為T[]
//初始化順序表的長度
this.N = 0;
}
下面進行功能實現(xiàn):
將線性表置為空表
// 將一個線性表置為空表
public void clear(){
//只需將順序表的長度變?yōu)?即可
this.N=0;
}
//我們使用this的原因是:一定指的是成員變量,防止有局部變量和成員變量同名。
//只要涉及到成員變量盡量用this修飾
判斷線性表是否為空表
//判斷當(dāng)前線性表是否為空表
public boolean isEmpty(){
//是否為空只需要判斷線性表中的元素個數(shù)
return this.N==0;
}
獲取線性表的長度
//獲取線性表的長度
public int length(){
//只需返回N即可
return this.N;
}
獲取i位置的元素
//獲取指定i位置的元素
public T get(int i){
//因為順序表是一個數(shù)組,只需要通過索引找到該元素即可
return eles[i];
}
向線性表中添加元素t
//向線性表中添加元素t
public void insert(T t){//T表示的元素的類型
//這個表示非常的巧妙,將元素加1的同時又將索引N的位置賦值了元素
eles[N++]=t;
//這個表示等價于eles[N]=t;N++;
}
在索引i處插入元素t
//在i元素初插入元素t
public void insert(int i,T t){
//先把i索引處的元素及其后面的元素依次向后移動一位
for (int index=N;index>i;index--){
//依次把前一位的值給后一位
eles[index]=eles[index-1];
}
//再把t元素放到i索引處,數(shù)組長度加1
eles[i]=t;
N++;
}
插入示意圖 :

刪除指定位置i處的元素,并返回該元素
//刪除指定位置i處的元素,并返回該元素
public T remove(int i){
//先定義個一變量記錄i位置的元素,后續(xù)用來返回該值
T current=eles[i];
//索引i后面元素依次向前移動一位
for (int index=0;index<N-1;index++){
//和前面的插入操作類似
eles[index]=eles[index+1];
}
//元素個數(shù)減1,返回被該(i覆蓋)的值
N--;
return current;
}
返回元素t第一次出現(xiàn)的值
//查找元素t第一次出現(xiàn)的位置
public int indexOf(T t){
for (int i=0;i<N;i++){
if(eles[i].equals(t)){
return i;
}
}
//for之后還沒找到返回-1
return -1;
}
3.3完整的API概覽:
//定義一個泛型類
public class SequenceList<T> {
//定義一個存儲元素的數(shù)組(先定義為泛型)
private T[] eles;
//定義一個變量表示順序表中的元素個數(shù)
private int N;
//添加構(gòu)造方法,用來初始化成員變量
public SequenceList(int capacity) {//接受一個容量長度
//初始化數(shù)組
this.eles = (T[]) new Object[capacity];//創(chuàng)建的是Object類型的所以需要強轉(zhuǎn)為T[]
//初始化順序表的長度
this.N = 0;
}
// 將一個線性表置為空表
public void clear(){
//只需將順序表的長度變?yōu)?即可
this.N=0;
//我們使用this的原因是:一定指的是成員變量,防止有局部變量和成員變量同名。
}
//判斷當(dāng)前線性表是否為空表
public boolean isEmpty(){
//是否為空只需要判斷線性表中的元素個數(shù)
return this.N==0;
}
//獲取線性表的長度
public int length(){
//只需返回N即可
return this.N;
}
//獲取指定i位置的元素
public T get(int i){
//因為順序表是一個數(shù)組,只需要通過索引找到該元素即可
return eles[i];
}
//向線性表中添加元素t
public void insert(T t){//T表示的元素的類型
//這個表示非常的巧妙,將元素加1的同時又將索引N的位置賦值了元素
eles[N++]=t;
//這個表示等價于eles[N]=t;N++;
}
//在i元素初插入元素t
public void insert(int i,T t){
//先把i索引處的元素及其后面的元素依次向后移動一位
for (int index=N;index>i;index--){
//依次把前一位的值給后一位
eles[index]=eles[index-1];
}
//再把t元素放到i索引處,數(shù)組長度加1
N++;eles[i]=t;
}
//刪除指定位置i處的元素,并返回該元素
public T remove(int i){
//先定義個一變量記錄i位置的元素,后續(xù)用來返回該值
T current=eles[i];
//索引i后面元素依次向前移動一位
for (int index=0;index<N-1;index++){
//和前面的插入操作類似
eles[index]=eles[index+1];
}
//元素個數(shù)減1,返回被覆蓋的值
N--;
return current;
}
//查找元素t第一次出現(xiàn)的位置
public int indexOf(T t){
for (int i=0;i<N;i++){
if(eles[i].equals(t)){
return i;
}
}
//for之后還沒找到返回-1
return -1;
}
}
四、順序表的測試:
public class SequenceListText {
public static void main(String[] args) {
//創(chuàng)建對象,指定類型
SequenceList<String> sl=new SequenceList<String>(10);
//插入元素
sl.insert("孔超");
sl.insert("劉詩勁");
sl.insert(0,"孫嘉輝");
//獲取元素
String s=sl.get(0);
System.out.println(s);//孫嘉輝
//刪除元素
String remove1=sl.remove(0);
System.out.println(remove1);
//清空元素
sl.clear();
System.out.println(sl.length());//0
}
}
到此這篇關(guān)于Java 順序表專題解讀的文章就介紹到這了,更多相關(guān)Java 順序表內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring?Cloud?Gateway?服務(wù)網(wǎng)關(guān)的部署與使用詳細講解
這篇文章主要介紹了Spring?Cloud?Gateway?服務(wù)網(wǎng)關(guān)的部署與使用詳細介紹,本文給大家講解的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-04-04
mybatis-plus阻止全表更新與刪除的實現(xiàn)
BlockAttackInnerInterceptor 是mybatis-plus的一個內(nèi)置攔截器,用于防止惡意的全表更新或刪除操作,本文主要介紹了mybatis-plus阻止全表更新與刪除的實現(xiàn),感興趣的可以了解一下2023-12-12
詳解SpringCloud Finchley Gateway 統(tǒng)一異常處理
這篇文章主要介紹了詳解SpringCloud Finchley Gateway 統(tǒng)一異常處理,非常具有實用價值,需要的朋友可以參考下2018-10-10
spring boot task實現(xiàn)動態(tài)創(chuàng)建定時任務(wù)的方法
這篇文章主要介紹了spring boot task實現(xiàn)動態(tài)創(chuàng)建定時任務(wù),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-01-01
Java數(shù)據(jù)結(jié)構(gòu)之實現(xiàn)哈希表的分離鏈接法
今天給大家?guī)淼氖顷P(guān)于Java數(shù)據(jù)結(jié)構(gòu)的相關(guān)知識,文章圍繞著Java哈希表的分離鏈接法展開,文中有非常詳細的介紹及代碼示例,需要的朋友可以參考下2021-06-06
基于java file 文件操作operate file of java的應(yīng)用
本篇文章介紹了,基于java file 文件操作operate file of java的應(yīng)用。需要的朋友參考下2013-05-05
java 中InputStream,String,File之間的相互轉(zhuǎn)化對比
這篇文章主要介紹了java 中InputStream,String,File之間的相互轉(zhuǎn)化對比的相關(guān)資料,需要的朋友可以參考下2017-04-04

