内容简介:数组最好写得支持泛型public class Array<T> {java不支持直接new一个泛型,必须先new一个Object,然后前面进行
数组最好写得支持泛型
public class Array<T> {
#T是自己自定义的一个类型 }
java不支持直接new一个泛型,必须先new一个Object,然后前面进行 类型转换
data = (E[]) new Object[capacity]
动态数组:扩容部分
if size == length :
resize(2*data.length);
private void resize(int newcapacity) {
E[] newData = (E[]) new Object[newcapacity]; for(int i=0;i<size;i++) { newdata[i] = data[i]; } data = newdata
复杂度震荡问题:本来removelast,和addlast操作,均摊的时间复杂度是O(n),但是如果操作到了需要扩容或缩容的元素,频繁的进行,removelast,然后又addlast,这样一直是O(n)
出现这样问题的原因呢:我们添加和删除时候的扩容太激进了,(too eager),应该元素个数变成总容量1/4的时候,我们只缩容到容量的一半,而不是过于激进,直接缩容到1/4
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
CSS 压缩/解压工具
在线压缩/解压 CSS 代码
在线进制转换器
各进制数互转换器