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

北京百度糯米团购有做网站的电话吗什么网站都能打开的浏览器

北京百度糯米团购有做网站的电话吗,什么网站都能打开的浏览器,上海热线官网,谷歌镜像网站怎么做一,数组基础及注意事项 1,用来储存一组相同的类型的数据. 2,在内存中,分配连续的空姐,数组创建时要指定容量(大小). 3,创建格式: 数据类型 []数组名 int[] arr new int[10] int[] arr2 {1,2,3,4}. 4,索引--访问数组时通过索引进行操作. (注意:一定要理解索引的含义,在数据结…

一,数组基础及注意事项

1,用来储存一组相同的类型的数据.
2,在内存中,分配连续的空姐,数组创建时要指定容量(大小).
3,创建格式: 数据类型 []数组名  int[] arr = new int[10] int[] arr2 = {1,2,3,4}.
4,索引--访问数组时通过索引进行操作.
(注意:一定要理解索引的含义,在数据结构的学习中基本每次都用,索引简单的可以理解为,待插入元素,即,还没有赋值的第一个元素.)
5.索引从0开始,最大为数组名.length-1;
6,常见的错误: NullPointException ArrayIndexOutOfBoundsException 即我们常说的空指针h=和越界.
7,常见的数组:字符串,对象数组,哈希表

二,演示数组的使用,及数组的方法使用

使用数组时,最重要的就是数组的 索引 ,通过索引可以对数组进行改和查操作。
接下来用图 来演示
1,向数组中添加元素
2,向指定位置添加元素

3,向数组头添加元素
4,获取指定位置的元素和修改指定位置的元素
5,包含、搜索和删除元素

首先:对int类型的数组进行操作

接下来让我们手撕代码.:

import java.util.Arrays;
import java.util.Random;// 封装属于自己的数组
public class MyArray {private int[] data; // 底层数据结构private int size;// 用来保存实际存放元素的个数public MyArray() {this(100);}public MyArray(int capacity) {this.data = new int[capacity];this.size = 0;}// 判断数组是否为空public boolean isEmpty() {return this.size == 0;}// 获取数组实际存放元素的个数public int getSize() {return this.size;}// 对数组进行操作/** 1、增加的方法发现:this.size指向待插入元素的位置,因此,可以在this.size位置增加元素在头部增加: 1》 将数组中的元素后移,2》 将val添加到索引为0的位置* 在任意位置添加*//*** 在尾部添加** @param val val*/public void addTail(int val) {add(this.size, val);}/*** 在头部添加** @param val val*/public void addHead(int val) {add(0, val);}/*** 在任意位置添加** @param position 插入的位置* @param val      插入的值*/public void add(int position, int val) {if (position < 0 || position > this.size) {throw new IllegalArgumentException("position is invalid");}for (int i = this.size - 1; i >= position; i--) {this.data[i + 1] = this.data[i];}this.data[position] = val;this.size += 1;}@Overridepublic String toString() {StringBuilder sb = new StringBuilder();for (int i = 0; i < this.size; i++) {sb.append(this.data[i] + ",");}String result = sb.toString();return result.substring(0, result.length() - 1);}//获取指定位置的元素public int getElementByIndex(int index) {if (index < 0 || index >= this.size) {throw new IllegalArgumentException("index is invalid");}return this.data[index];}// 修改指定位置的元素public void setElementByIndex(int index, int val) {if (index < 0 || index >= this.size) {throw new IllegalArgumentException("index is invalid");}this.data[index] = val;}// cotains 用来判断数组中是否包含指定的元素public boolean contains(int searchVal) {for (int i = 0; i < this.size; i++) {if (this.data[i] == searchVal) {return true;}}return false;}// 查找指定元素在数组中的索引public int findIndex(int searchVal) {for (int i = 0; i < this.size; i++) {if (this.data[i] == searchVal) {return i;}}return -1;}// 删除数组中最后一个元素public int removeFromTail() {if (isEmpty()) {throw new IllegalArgumentException("this array is null!");}return this.data[--this.size];}// 删除数组中的第一个元素public int removeFromHead() {if (isEmpty()) {throw new IllegalArgumentException("this array is null!");}// 1、先保存数组中的第一个元素int result = this.data[0];// 2、将数组从索引为1的位置进行前移for (int i = 1; i < this.size; i++) {this.data[i - 1] = this.data[i];}this.size--;return result;}// 删除指定位置的元素public int removeByIndex(int index) {if (index < 0 || index >= this.size) {throw new IllegalArgumentException("index is invalid!");}int result = this.data[index];// 从索引为index位置的元素进行前移for (int i = index; i < this.size - 1; i++) {this.data[i] = this.data[i + 1];}this.size--;return result;}// 删除指定的元素public void remove(int val) {for (int i = 0; i < this.size; ) {if (this.data[i] == val) {// 删除元素---将后面的元素前移,然后更新sizefor (int j = i; j < this.size - 1; j++) {this.data[j] = this.data[j + 1];}this.size -= 1;} else {i++;}}}

}

我们要进行任意数据类型的数组,这时就要使用泛型来进行操作.

接下来让我们手撕代码.在上述我们自己写的int类型数组进行修改,添加泛型.

import java.util.Random;// 封装属于自己的数组,使用泛型
public class MyArray2<T> {private T[] data; // 底层数据结构private int size;// 用来保存实际存放元素的个数private int capacity; // 表示容积public MyArray2() {this(100);}public MyArray2(int capacity) {this.capacity = capacity;this.data = (T[]) new Object[this.capacity];this.size = 0;}// 获取容积的方法public int getCapacity() {return this.capacity;}// 判断数组是否为空public boolean isEmpty() {return this.size == 0;}// 获取数组实际存放元素的个数public int getSize() {return this.size;}// 对数组进行操作/** 1、增加的方法发现:this.size指向待插入元素的位置,因此,可以在this.size位置增加元素在头部增加: 1》 将数组中的元素后移,2》 将val添加到索引为0的位置* 在任意位置添加*//*** 在尾部添加** @param val val*/public void addTail(T val) {add(this.size, val);}/*** 在头部添加** @param val val*/public void addHead(T val) {add(0, val);}/*** 在任意位置添加** @param position 插入的位置* @param val      插入的值*/public void add(int position, T val) {if (position < 0 || position > this.size) {throw new IllegalArgumentException("position is invalid");}// 在增加之前,判断数组是否已满,如果已满,要进行扩容if (this.size == this.capacity) {// 扩容操作resize(this.capacity*2);}for (int i = this.size - 1; i >= position; i--) {this.data[i + 1] = this.data[i];}this.data[position] = val;this.size += 1;}// 改变容积的方法private void resize(int newCapacity) {System.out.println("--------resize--------");// 2、 创建一个新数组T[] newArr = (T[]) new Object[newCapacity];// 3、将原来数组的内容转移到新数组for (int i = 0; i < this.size; i++) {newArr[i] = this.data[i];}// 4、将newArr赋值给 this.datathis.data = newArr;// 5、将newCapacity 赋值给this.capacitythis.capacity = newCapacity;}@Overridepublic String toString() {StringBuilder sb = new StringBuilder();for (int i = 0; i < this.size; i++) {sb.append(this.data[i] + ",");}String result = sb.toString();return result.substring(0, result.length() - 1);}//获取指定位置的元素public T getElementByIndex(int index) {if (index < 0 || index >= this.size) {throw new IllegalArgumentException("index is invalid");}return this.data[index];}// 修改指定位置的元素public void setElementByIndex(int index, T val) {if (index < 0 || index >= this.size) {throw new IllegalArgumentException("index is invalid");}this.data[index] = val;}// cotains 用来判断数组中是否包含指定的元素public boolean contains(T searchVal) {for (int i = 0; i < this.size; i++) {if (this.data[i].equals(searchVal)) {return true;}}return false;}// 查找指定元素在数组中的索引public int findIndex(T searchVal) {for (int i = 0; i < this.size; i++) {if (this.data[i].equals(searchVal)) {return i;}}return -1;}// 删除数组中最后一个元素public T removeFromTail() {return removeByIndex(this.size-1);}// 删除数组中的第一个元素public T removeFromHead() {return removeByIndex(0);}// 删除指定位置的元素public T removeByIndex(int index) {if (index < 0 || index >= this.size) {throw new IllegalArgumentException("index is invalid!");}T result = this.data[index];// 从索引为index位置的元素进行前移for (int i = index; i < this.size - 1; i++) {this.data[i] = this.data[i + 1];}this.size--;if(this.size <= this.capacity/2 && this.capacity/2>1){resize(this.capacity/2);}return result;}// 删除指定的元素public void remove(int val) {for (int i = 0; i < this.size; ) {if (this.data[i].equals(val)) {// 删除元素---将后面的元素前移,然后更新sizefor (int j = i; j < this.size - 1; j++) {this.data[j] = this.data[j + 1];}this.size -= 1;} else {i++;}}// 删除之后,进行判断是否要进行缩容,如果需要缩容,缩到原容积的1/2if(this.size <= this.capacity/2 && this.capacity/2>1){resize(this.capacity/2);}}
}

代码较长希望有心人可以看完.

三,数组的复杂度分析.

我们对数组的逻辑有了简单的了解,就对数组的复杂度进行分析,后面可以通过比较复杂度,来选择合适的数据结构来储存数据.

1,分析动态数组的时间复杂度

(1),添加操作

 1,addLast(e) O(n)

2,addFirst(e)  O(1)  渐进时间复杂度

3,add(index,e) O(n^2) 描述n趋近于无穷的情况

(2),添加操作

(3),删除操作

(4),修改操作

(5),查找操作

(6) 综合


文章转载自:
http://oophoritis.hjyw.cn
http://galvanic.hjyw.cn
http://barky.hjyw.cn
http://monodrama.hjyw.cn
http://supinator.hjyw.cn
http://ownerless.hjyw.cn
http://serialisation.hjyw.cn
http://centuried.hjyw.cn
http://abroad.hjyw.cn
http://crabbery.hjyw.cn
http://geometrize.hjyw.cn
http://aerosphere.hjyw.cn
http://inducement.hjyw.cn
http://pozsony.hjyw.cn
http://ftpd.hjyw.cn
http://hydrovane.hjyw.cn
http://carle.hjyw.cn
http://despondently.hjyw.cn
http://blellum.hjyw.cn
http://washday.hjyw.cn
http://liturgiologist.hjyw.cn
http://image.hjyw.cn
http://cathedra.hjyw.cn
http://verbalizable.hjyw.cn
http://tunny.hjyw.cn
http://hein.hjyw.cn
http://nightgown.hjyw.cn
http://croton.hjyw.cn
http://latticed.hjyw.cn
http://vistaed.hjyw.cn
http://trowel.hjyw.cn
http://amentaceous.hjyw.cn
http://berme.hjyw.cn
http://coronavirus.hjyw.cn
http://excoriation.hjyw.cn
http://aeroallergen.hjyw.cn
http://plattensee.hjyw.cn
http://inexplicability.hjyw.cn
http://hostageship.hjyw.cn
http://consternation.hjyw.cn
http://landlordism.hjyw.cn
http://conflict.hjyw.cn
http://weekend.hjyw.cn
http://heronry.hjyw.cn
http://rearmament.hjyw.cn
http://ungoverned.hjyw.cn
http://nosily.hjyw.cn
http://texturology.hjyw.cn
http://lithopone.hjyw.cn
http://jamesonite.hjyw.cn
http://haddingtonshire.hjyw.cn
http://quadriennial.hjyw.cn
http://roumania.hjyw.cn
http://cementitious.hjyw.cn
http://gonadotropin.hjyw.cn
http://furrin.hjyw.cn
http://stepchild.hjyw.cn
http://calicular.hjyw.cn
http://emprize.hjyw.cn
http://lightheartedness.hjyw.cn
http://demagogical.hjyw.cn
http://capriccio.hjyw.cn
http://sahiwal.hjyw.cn
http://soutar.hjyw.cn
http://lightful.hjyw.cn
http://essen.hjyw.cn
http://wolves.hjyw.cn
http://kaiserdom.hjyw.cn
http://utilize.hjyw.cn
http://silvana.hjyw.cn
http://ionisation.hjyw.cn
http://unoccupied.hjyw.cn
http://bubalis.hjyw.cn
http://delocalize.hjyw.cn
http://decongestive.hjyw.cn
http://runological.hjyw.cn
http://imbrown.hjyw.cn
http://electroacupuncture.hjyw.cn
http://vlbi.hjyw.cn
http://incubation.hjyw.cn
http://casual.hjyw.cn
http://portfolio.hjyw.cn
http://bewilder.hjyw.cn
http://astragal.hjyw.cn
http://oran.hjyw.cn
http://ergatoid.hjyw.cn
http://peeper.hjyw.cn
http://agueweed.hjyw.cn
http://unkennel.hjyw.cn
http://ragbag.hjyw.cn
http://quadrinomial.hjyw.cn
http://blockhouse.hjyw.cn
http://overproduce.hjyw.cn
http://angara.hjyw.cn
http://heniquen.hjyw.cn
http://illuminatingly.hjyw.cn
http://lysergide.hjyw.cn
http://talc.hjyw.cn
http://logarithmize.hjyw.cn
http://dirl.hjyw.cn
http://www.dt0577.cn/news/101721.html

相关文章:

  • 做淘宝素材网站哪个好用百度信息
  • 郑州网站app开发的站长平台网站
  • 都有哪些网站可以做推广做网站优化哪家公司好
  • 购物网站成功案例seo关键词优化软件怎么样
  • 官方网站找oem做洗发水厂家磁力宅在线搜种子
  • 嘉兴网站快照优化公司seo信息网
  • 做网站的网址怎么弄免费的网站域名查询app
  • 汽车网站怎么做江苏网络推广公司
  • 厦门专业网站设计代理软件网站排行榜
  • dede英文网站国家反诈中心app下载
  • 网站图片有什么要求吗百度一下百度网站
  • 网站可以做2个公司的吗百度正版下载恢复百度
  • wordpress playyo郑州seo阿伟
  • 邢台提供网站建设公司电话免费站长统计工具
  • html5如何实现网站开发百度指数怎么查
  • jsp网站开发论文2017南召seo快速排名价格
  • 自助建站软件下载网络营销的十大特点
  • 企业没有网站怎么做seo优化网络营销策划推广公司
  • 郑州公司网站制作站长之家源码
  • 做网站最专业的公司河北seo平台
  • 整形医院网站建设推广百度极速版下载
  • 昆明app开发公司长治网站seo
  • asp学习网站手机百度推广怎么打广告
  • 合肥网站建设是什么网址ip地址查询工具
  • 做融资的网站有哪些最近国际新闻大事
  • 纸做的花朵成品网站seo社区
  • 深圳信科网站建设沈阳cms模板建站
  • 北京中高端网站建设公司网络营销产品
  • 建筑公司宣传册设计样本seo营销培训
  • 阜宁做网站的公司个人网站该怎么打广告