当前位置: 首页 > news >正文

企业展示网站建设wordpress 优酷免广告

企业展示网站建设,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底层是一段连续的空间并且可以动态扩容是一个动态类型的顺序表
http://www.pierceye.com/news/495870/

相关文章:

  • 濮阳做网站引导企业做网站
  • 卧龙区网站建设找做牙工作上哪个网站
  • 做网站的会计分录广州公司注册需要什么条件
  • 小米4路由器可以做网站嘛服务类网站建设服务公司
  • 电子商务网站建设规划书实例注册微信公众平台
  • 网站设计课程总结线上营销方案
  • 谷城网站建设网站集群建设实施方案
  • 怎么做外贸生意谷歌seo服务
  • 做网站好还是做淘宝好市场调研模板
  • 网站做换肤做一个平台费用是多少
  • 省内注销二建 建设部网站更新慢网站建设合同书封皮
  • 天津城市建设网站营销型网站的好处
  • 网站建设维护文档好看的页面
  • 网站搜索优化官网网站建设在电子商务中的作用的看法
  • 网站推广费用价格html大屏展示模板
  • 编辑网站用什么软件网站开发人员职责
  • 网站搜索引擎提交wordpress发布站点
  • 阳春网站建设天水网站seo
  • 仙桃市建设局网站wordpress链接前面的图标
  • 温州市城乡建设建档案馆网站公司装修费用可以一次性入账吗
  • 房地产开发公司网站宠物网页设计模板
  • 网站备案信息可以改吗中国做二手房最大的网站
  • 设计 企业网站罗湖网站-建设深圳信科
  • 太原自助模板建站手机版电脑qq登录入口
  • 公司网站建设哪家比较好app 网站
  • 建设银行个人网站打不开个人主页模板下载
  • 山西建设公司网站wordpress视频适应手机端
  • 原型样网站做一般的公司门户网站投资额
  • 南宁百度网站公司电话网站配置优化
  • 德州网站建设的公司免费注册公司怎么注册