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

十大奢侈品牌logo图片做关键词优化的公司

十大奢侈品牌logo图片,做关键词优化的公司,网页端二维码在哪里,网站建设空间使用标准文章目录 1.了解什么是顺序表2.实现哪些功能3.初始化ArrayList4.实现功能接口遍历顺序表判断顺序表是否已满添加元素指定下标添加元素自定义下标不合法异常判断顺序表是否为空查找指定元素是否存在查找指定元素返回下标获取指定下标的元素顺序表为空异常修改指定下标元素的值删…

文章目录

  • 1.了解什么是顺序表
  • 2.实现哪些功能
  • 3.初始化ArrayList
  • 4.实现功能接口
    • 遍历顺序表
    • 判断顺序表是否已满
    • 添加元素
    • 指定下标添加元素
    • 自定义下标不合法异常
    • 判断顺序表是否为空
    • 查找指定元素是否存在
    • 查找指定元素返回下标
    • 获取指定下标的元素
    • 顺序表为空异常
    • 修改指定下标元素的值
    • 删除指定元素
    • 顺序表长度
    • 回收顺序表
  • 完整代码

1.了解什么是顺序表

顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储。在数组上完成数据的增删查改。

2.实现哪些功能

对于一个顺序表来说
我们做的最多的也就是增删查改
则实现以下接口:

public interface IList {//新增元素,默认在数组最后新增public void add(int data);// 在 pos 位置新增元素public void add(int pos, int data);// 判定是否包含某个元素public boolean contains(int toFind) ;// 查找某个元素对应的位置public int indexOf(int toFind);// 获取 pos 位置的元素public int get(int pos);// 给 pos 位置的元素设为 value  更新public void set(int pos, int value);//删除第一次出现的关键字keypublic void remove(int toRemove) ;// 获取顺序表长度public int size();// 清空顺序表public void clear() ;// 打印顺序表,注意:该方法并不是顺序表中的方法,为了方便看测试结果给出的public void display();//判断是否已满boolean isFull();//判断是否为空public boolean isEmpty();
}

3.初始化ArrayList

usedSize为使用的长度
DEFAULT_SIZE = 10为默认顺序表的容量
两个构造方法
无参构造:顺序表默认大小为10;
有参构造:自定义顺序表大小;

public class MyList implements IList{public int[] elem ;public int usedSize;//0//顺序表的 默认大小public static final int DEFAULT_SIZE = 10;public MyList(){this.elem = new int[DEFAULT_SIZE];}public MyList(int capacity){this.elem = new int[capacity];}}

4.实现功能接口

遍历顺序表

public void display(){for (int i = 0; i < usedSize; i++) {System.out.print(elem[i]+" ");}System.out.println();}

判断顺序表是否已满

public boolean isFull(){return usedSize == elem.length;}

添加元素

checkCapacity()判断顺序表是否已满,如果已经满了则进行扩容
扩容为原来顺序表的两倍

 private void checkCapacity(){if(isFull()){elem = Arrays.copyOf(elem,elem.length*2);}}public void add(int data){checkCapacity();elem[this.usedSize] = data;this.usedSize++;}

指定下标添加元素

checkPosOnAdd()判断下标是否合法,如果不合法抛出异常

public void checkPosOnAdd(int pos) throws PosIllegality{if(pos < 0 || pos >usedSize){System.out.println("不合法!");throw new PosIllegality("获取指定下标的元素异常: "+pos);}}public void add(int pos, int data){try{checkPosOnAdd(pos);}catch (PosIllegality e){e.printStackTrace();return;}checkCapacity();for (int i = usedSize-1; i >= pos; i--) {elem[i+1] = elem[i];}elem[pos] = data;usedSize++;}

自定义下标不合法异常

package mylist;public class PosIllegality extends RuntimeException{public PosIllegality(String msg){super(msg);}
}

判断顺序表是否为空

public boolean isEmpty(){return usedSize == 0;}

查找指定元素是否存在

  public boolean contains(int toFind){if(isEmpty()){return false;}for (int i = 0; i < usedSize; i++) {if(elem[i] == toFind){return true;}}return false;}

查找指定元素返回下标

 public int indexOf(int toFind){if(isEmpty()){return -1;}for (int i = 0; i < usedSize; i++) {if(elem[i] == toFind){return i;}}return -1;}

获取指定下标的元素

public void checkPosOnGetAndSet(int pos) throws PosIllegality {if(pos < 0 || pos >= usedSize){System.out.println("不合法");throw new PosIllegality("获取指定下标的元素异常: "+pos);}}public int get(int pos) throws MyArrayListEmpty{checkPosOnGetAndSet(pos);if(isEmpty()){throw new MyArrayListEmpty("获取指定下标元素时" +"顺序表为空!");}return elem[pos];}

顺序表为空异常

package mylist;public class MyArrayListEmpty extends RuntimeException{public MyArrayListEmpty(String msg){super(msg);}
}

修改指定下标元素的值

public void set(int pos, int value){checkPosOnGetAndSet(pos);elem[pos] = value;}

删除指定元素

  public void remove(int toRemove){int index = indexOf(toRemove);if(index == -1){System.out.println("没有找到");return;}for (int i = index; i < usedSize - 1; i++) {elem[i] =elem[i+1];}usedSize--;}

顺序表长度

  public int size(){return this.usedSize;}

回收顺序表

 public void clear() {usedSize = 0;}

完整代码

在这里插入图片描述

package mylist;import java.util.Arrays;public class MyList implements IList{public int[] elem ;public int usedSize;//0//顺序表的 默认大小public static final int DEFAULT_SIZE = 10;public MyList(){this.elem = new int[DEFAULT_SIZE];}public MyList(int capacity){this.elem = new int[capacity];}public void display(){for (int i = 0; i < usedSize; i++) {System.out.print(elem[i]+" ");}System.out.println();}public boolean isFull(){return usedSize == elem.length;}private void checkCapacity(){if(isFull()){elem = Arrays.copyOf(elem,elem.length*2);}}public void add(int data){checkCapacity();elem[this.usedSize] = data;this.usedSize++;}public void checkPosOnAdd(int pos) throws PosIllegality{if(pos < 0 || pos >usedSize){System.out.println("不合法!");throw new PosIllegality("获取指定下标的元素异常: "+pos);}}public void add(int pos, int data){try{checkPosOnAdd(pos);}catch (PosIllegality e){e.printStackTrace();return;}checkCapacity();for (int i = usedSize-1; i >= pos; i--) {elem[i+1] = elem[i];}elem[pos] = data;usedSize++;}public boolean isEmpty(){return usedSize == 0;}public boolean contains(int toFind){if(isEmpty()){return false;}for (int i = 0; i < usedSize; i++) {if(elem[i] == toFind){return true;}}return false;}public int indexOf(int toFind){if(isEmpty()){return -1;}for (int i = 0; i < usedSize; i++) {if(elem[i] == toFind){return i;}}return -1;}public void checkPosOnGetAndSet(int pos) throws PosIllegality {if(pos < 0 || pos >= usedSize){System.out.println("不合法");throw new PosIllegality("获取指定下标的元素异常: "+pos);}}public int get(int pos) throws MyArrayListEmpty{checkPosOnGetAndSet(pos);if(isEmpty()){throw new MyArrayListEmpty("获取指定下标元素时" +"顺序表为空!");}return elem[pos];}public void set(int pos, int value){checkPosOnGetAndSet(pos);elem[pos] = value;}public void remove(int toRemove){int index = indexOf(toRemove);if(index == -1){System.out.println("没有找到");return;}for (int i = index; i < usedSize - 1; i++) {elem[i] =elem[i+1];}usedSize--;}public int size(){return this.usedSize;}public void clear() {usedSize = 0;}
}
http://www.ritt.cn/news/5606.html

相关文章:

  • 珠海政府网站大湾区建设百度云盘网页登录入口
  • 湖南做网站的公司排名市场调研问卷调查怎么做
  • 自网站EXCel数据导入怎么做口碑营销的方法
  • webgis前端框架西安百度网站快速优化
  • 慈溪机械加工网seo关键词优化的技巧和方法
  • 如何修改wordpress主题模板企业怎么做好网站优化
  • 如何用iis做网站seo排名的公司
  • wordpress智能石家庄全网seo
  • 免费网站建设图书下载长沙快速排名优化
  • wordpress 内部标签青岛seo网站排名优化
  • wap网站域名石家庄网站关键词推广
  • 从零开始做电影网站优化大师app
  • 郑州知名网站建设公司排名营销策略分析包括哪些内容
  • wordpress 建站 图床潍坊网站建设平台
  • 企业建设网站的步骤是什么?天津海外seo
  • 如何做电影网站赚钱网站seo优化发布高质量外链
  • 个人博客网站建设分析网站
  • 铭万做的网站百度推广登陆入口
  • 四川住建管理平台官网站长工具seo综合查询论坛
  • 响应式网站建设 苏州看片应该搜什么关键词哪些词
  • php网站建设填空题百度推广关键词和创意
  • vs2017 做网站十大免费网站推广
  • 网站模板框架爱站网关键词工具
  • 免费网站建设软件大全河北关键词seo排名
  • 网站开发仓库管理系统需求分析营销方法
  • 加盟招商推广网站seo在线优化技术
  • 唐山网站建设公司重庆seo网络优化咨询热线
  • 网站建设的基本目标软文写作服务
  • 陆良网站建设企业网站推广策划书
  • 切实加强政府网站建设与管理国家卫健委最新疫情报告