Java實現順序表
一、什麼是順序表?
順序表就是用一組地址連續的儲存單元儲存各個元素,使得其在邏輯上相鄰,物理上也相鄰,以陣列的形式儲存資料。
二、順序表的常見操作:
1.建立類和構造方法
public class MyArrayList {
private int [] elem;
private int usedSize;
public MyArrayList(){
this.elem = new int [10];
}
public MyArrayList(int capacity){
this.elem = new int[capacity];
}
}
2.擴容
public void resize(){
this.elem = Arrays.copyOf(this.elem,2*this.elem.length);
}
3.判斷順序表是否為滿
public boolean isFull(){
if(this.usedSize == this.elem.length){
return true;
}
return false;
}
4.列印順序表
public void display() {
for (int i = 0;i < usedSize; i++) {
System.out.print(elem[i]+" ");
}
System.out.println();
}
5.在pos位置新增元素
public void add(int pos, int data) {
if(isFull()){
System.out.println("連結串列已滿!");
resize();
}
if(pos < 0 || pos > this.usedSize){
System.out.println("插入位置不合法!");
return;
}
for (int i = usedSize-1; i >= pos;i--) {
elem[i+1] = elem[i];
}
elem[pos] = data;
this.usedSize++;
}
6.判斷是否包含某個元素
public boolean contains(int toFind) {
for(int i = 0; i < usedSize;i++){
if(elem[i] == toFind){
return true;
}
}
return false;
}
7.查詢某個元素對應的位置
public int search(int toFind) {
for(int i = 0; i < usedSize;i++){
if(elem[i] == toFind){
return i;
}
}
return -1;
}
8.獲取pos位置的元素
public int getPos(int pos) {
if(pos < 0 || pos >= usedSize){
System.out.println("該pos位置不合法!");
return -1;
}
return elem[pos];
}
9.給pos位置的元素修改為value
public void setPos(int pos, int value) {
if(pos < 0 || pos >= usedSize){
System.out.println("該pos位置不合法!");
return;
}
elem[pos] = value;
}
10.刪除第一次出現的關鍵字Key
public void remove(int toRemove) {
int index = -1;
for(int i = 0; i < this.usedSize;i++){
if(this.elem[i] == toRemove){
index = i;
}
}
if(index == -1){
System.out.println("未找到該元素!");
return;
}
for(int j = index;j < this.usedSize-1;j++){
this.elem[j] = this.elem[j+1];
}
this.usedSize--;
}
11.獲取連結串列長度
public int size() {
return this.usedSize;
}
12.清空順序表
public void clear() {
this.usedSize = 0;
}
相關文章
- 順序表的實現
- DS順序表--類實現
- 線性表的使用——順序實現
- 順序表實現二分排序排序
- 線性表-順序表C語言實現C語言
- 資料結構實驗一:順序表的建立與操作實現、順序表實現約瑟夫環問題資料結構
- 順序表
- 順序表的基本方法實現C語言版C語言
- 順序表應用5:有序順序表歸併
- 順序表應用6:有序順序表查詢
- 實驗二:順序表的基本操作實現及其應用
- 順序棧的實現方式
- 第2章 順序表及其順序儲存
- 資料結構c語言實現順序表基本操作資料結構C語言
- 線性表的順序儲存C++程式碼實現C++
- 資料結構_順序表_順序表的初始化、插入、刪除、修改、查詢列印(基於C語言實現)資料結構C語言
- 具體實現程式碼@資料結構探險——順序表資料結構
- 順序表的學習
- 順序表的堆排序排序
- 基礎資料結構(一)---(最全)定長順序表的實現資料結構
- 順序表有序插入資料
- 順序賦值的方式實現流水燈賦值
- Java父子類載入順序Java
- java運算子優先順序Java
- 資料結構 - 線性表 - 順序表資料結構
- 【資料結構】堆疊(順序棧、鏈棧)的JAVA程式碼實現資料結構Java
- 多執行緒實現順序迴圈列印執行緒
- 考研資料結構-線性表-順序表資料結構
- 線性表的順序儲存-順序表,對“突然的自我”的否定,對自我的揚棄
- java類初始化的順序Java
- Java框架學習順序是哪些Java框架
- Java框架學習順序是哪些?Java框架
- java setPriority()設定優先順序Java
- python實現基本資料結構第二篇(順序棧、鏈棧,順序隊、鏈隊)Python資料結構
- join、volatile、newSingleThreadLatch 實現執行緒順序執行thread執行緒
- 順序審批流的簡單程式碼實現
- 隨筆:MySQL 普通3表join順序MySql
- C++ 運算子優先順序表C++