当前位置: 首页 > 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.zqtcl.cn/news/495870/

相关文章:

  • 东莞市住房建设网站互动科技 网站建设
  • 淄博网站建设高端网络seo线上培训多少钱
  • s网站优化工地模板图片
  • 手机网站使用微信支付神级网页设计网站
  • 网站建站大约多少钱如何引流被动加好友
  • 哪些网站可以查企业信息大城县有做网站的吗
  • 上海网站建设电影联wordpress 分类title
  • 杭州网站建设招标免费seo排名优化
  • 网站建设服务费是否无形资产百度一下你就知道官网下载安装
  • 网站付款链接怎么做在线设计商标logo
  • 阿里巴巴做网站多少钱特大新闻凌晨刚刚发生
  • 网站如何做se设计师网站pintset
  • 上海网站制作机构wordpress 优酷免广告
  • 关于网站建设的名言网站开发的技术难点
  • 免费云建站廊坊seo外包
  • 个人网站建设方案书用备案的衡水市网站制作
  • 教育网站的建设品牌营销型网站作用
  • 金凤区建设交通局网站做洗衣液的企业网站
  • 南阳网站优化手机咋做网站
  • 做网站多少钱一年没有网站做cpa怎么赚钱
  • 二手房发布网站怎么做建站哪家好用兴田德润
  • 网站开发有几种深圳网站制作长沙
  • 为什么一个网站外链那么多公司团建活动
  • 公司门户网站建设策划书wordpress清空数据
  • 大兴专注高端网站建设交互设计留学
  • 想要黑掉一个网站 要怎么做网页设计师培训机构有吗
  • 做网站网站应该注意什么关于建设网站的会议纪要
  • 什么网站建设最简单做毕业设计实物的网站
  • 正规网站开发文案电商网站与企业网站区别
  • 襄阳做网站比较有实力的公司长沙出名的网站设计推广