企业展示网站建设,wordpress 优酷免广告,施工企业会计核算办法2021,住房和城乡建设局文章目录 前言顺序表1、打印顺序表2、增加元素3、在任意位置增加元素4、判断是否包含某个元素5、查找某个元素对于的位置6、获取任意位置的元素7、将任意位置的元素设为value8、删除第一次出现的关键字9、获取顺序表长度10、清空顺序表总结 前言
在了解顺序表之前我们要先了解… 文章目录 前言顺序表1、打印顺序表2、增加元素3、在任意位置增加元素4、判断是否包含某个元素5、查找某个元素对于的位置6、获取任意位置的元素7、将任意位置的元素设为value8、删除第一次出现的关键字9、获取顺序表长度10、清空顺序表总结 前言
在了解顺序表之前我们要先了解什么是线性表线性表linear list是n个具有相同特性的数据元素的有限序列。 线性表是一种在实际中广泛使用的数据结构常见的线性表顺序表、链表、栈、队列… 线性表在逻辑上是线性结构也就说是连续的一条直线。但是在物理结构上并不一定是连续的线性表在物理上存储时通常以数组和链式结构的形式存储 顺序表
顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构一般情况下采用数组存储。在数组上完成数据的增删查改 接下来我们要实现一些方法来对数组进行增删查改等操作
创建一个类
public class MyArrayList {//数组public int[] elem;//数组中的元素个数public int usedSize;//当前数组默认的容量public static final int DEFAULT_CAPACITY 5;public MyArrayList() {elem new int[DEFAULT_CAPACITY];}
} 1、打印顺序表
public void display() {for (int i 0; i usedSize; i) {System.out.print(elem[i] );}System.out.println();
} 2、增加元素
增加元素默认是在数组的最后位置增加元素 在增加元素之前我们要先判断数组是否满了
判读数组是否满
public boolean isFull() {return usedSize elem.length;
}增加元素
public void add(int data) {if(isFull()) {//满了进行扩容elem Arrays.copyOf(elem,2*elem.length);}elem[usedSize] data;usedSize;
}测试
public class Test {public static void main(String[] args) {MyArrayList myArray new MyArrayList();myArray.add(10);myArray.add(20);myArray.add(30);myArray.add(40);myArray.display();}
}3、在任意位置增加元素
注意这里的增加元素要保证位置的合法性不能小于0也不能大于数组的长度更不能间隔着插入即插入的位置前面一定要有元素同时插入时其余元素要后移如果不合法就抛一个异常 同样增加元素之前我们要判断数组是否满了
位置是否合法
private void checkPosOfAdd(int pos) {if(pos 0||pos usedSize) {throw new PosException(pos位置不合法:pos);}
} 任意位置增加元素
public void add(int pos, int data) {//判断位置是否合法checkPosOfAdd(pos);if(isFull()) {elem Arrays.copyOf(elem,2*elem.length);}for (int i usedSize - 1; i pos; i--) {elem[i1] elem[i];}elem[pos] data;usedSize;
} 测试
public class Test {public static void main(String[] args) {MyArrayList myArray new MyArrayList();myArray.add(10);myArray.add(20);myArray.add(30);myArray.add(40);myArray.add(1,15);myArray.display();}
}4、判断是否包含某个元素
遍历数组判断是否与这个元素相同
public boolean contains(int toFind) {for (int i 0; i usedSize; i) {if(elem[i] toFind) {return true;}}return false;
} 测试
public class Test {public static void main(String[] args) {MyArrayList myArray new MyArrayList();myArray.add(10);myArray.add(20);myArray.add(30);myArray.add(40);System.out.println(myArray.contains(20));System.out.println(myArray.contains(200));}
}5、查找某个元素对于的位置
遍历这个数组找与要查找的元素是否相同相同返回该元素的下标不同返回-1
public boolean indexOf(int toFind) {for (int i 0; i usedSize; i) {if(elem[i] toFind) {return i;}}return -1;
} 测试:
public class Test {public static void main(String[] args) {MyArrayList myArray new MyArrayList();myArray.add(10);myArray.add(20);myArray.add(30);myArray.add(40);System.out.println(myArray.indexOf(20));System.out.println(myArray.indexOf(200));}
}6、获取任意位置的元素
同样我们要判断该位置是否合法还有要判断顺序表是否为空两个条件都合法时返回该位置的元素
顺序表是否为空
public boolean isEmpty() {return usedSize 0;
} 获取任意位置的元素
public int get(int pos) {//判断该位置是否合法checkPosOfAdd(pos);if(isEmpty()) {throw new EmptyException(顺序表为空);}return elem[pos];
} 测试
public class Test {public static void main(String[] args) {MyArrayList myArray new MyArrayList();myArray.add(10);myArray.add(20);myArray.add(30);myArray.add(40);System.out.println(myArray.get(1));}
}7、将任意位置的元素设为value
与获取任意位置的元素方法相同要判断该位置是否合法还要判断顺序表是否为空
将任意位置的元素设为value
public void set(int pos, int value) {//判断位置是否合法checkPosOfAdd(pos);if(isEmpty()) {throw new EmptyException(顺序表为空);}this.elem[pos] value;
} 测试
public class Test {public static void main(String[] args) {MyArrayList myArray new MyArrayList();myArray.add(10);myArray.add(20);myArray.add(30);myArray.add(40);myArray.set(1,15);myArray.display();}
}8、删除第一次出现的关键字
在进行删除操作时要判断顺序表是否为空找到要删除元素的下标最后 挪动数据
删除操作 public void remove(int toRemove) {if(isEmpty()) {throw new EmptyException(顺序表为空);}int ret indexOf(toRemove);for (int i ret; i usedSize; i) {elem[i] elem[i1];}usedSize--;
} 测试
public class Test {public static void main(String[] args) {MyArrayList myArray new MyArrayList();myArray.add(10);myArray.add(20);myArray.add(30);myArray.add(40);myArray.remove(10);myArray.display();}
}9、获取顺序表长度
public int size() {return usedSize;
} 测试
public class Test {public static void main(String[] args) {MyArrayList myArray new MyArrayList();myArray.add(10);myArray.add(20);myArray.add(30);myArray.add(40);System.out.println(myArray.size());}
}10、清空顺序表
public void clear() {usedSize 0;
} 测试
public class Test {public static void main(String[] args) {MyArrayList myArray new MyArrayList();myArray.add(10);myArray.add(20);myArray.add(30);myArray.add(40);myArray.display();System.out.println(*******);myArray.clear();myArray.display();}
}总结
在集合框架中ArrayList是一个普通的类实现了List接口具体框架图如下 1.ArrayList是以泛型方式实现的使用时必须要先实例化 2.ArrayList实现了RandomAccess接口表明ArrayList支持随机访问 3.ArrayList实现了Cloneable接口表明ArrayList是可以clone的 4.ArrayList实现了Serializable接口表明ArrayList是支持序列化的 5.和Vector不同ArrayList不是线程安全的在单线程下可以使用在多线程中可以选择Vector或者 CopyOnWriteArrayList 6. ArrayList底层是一段连续的空间并且可以动态扩容是一个动态类型的顺序表