摘要:本文主要写了如何自定义一个长度可变数组
数组是在程序设计中,为了处理方便,把具有相同类型的若干元素按无序的形式组织起来的一种形式
在定义之初,数组的长度就被定义
新建数组有很多方式 下面两个都可以 但一般书写习惯会选择第一种
1 String[] array = new String[5]; //新建一个长度为5的字符串数组
1 String array[] = new String[5]; //新建一个长度为5的字符串数组
由于数组的长度一旦初始化就无法改变,所以我们需要另辟思路
假如我有一个只能装5个鸡蛋的篮子
现在我想多放入一个鸡蛋 但篮子放不下 怎么办!!
用传说中的四步法就可以解决这个问题啦
1.找一个能放下6个鸡蛋的容器!
2.将五个鸡蛋放入后来的容器!
3.将拿来的第六个鸡蛋也放入容器!
4.将之前的“篮子”标签撕下,贴在新容器上!
此时,我就有了一个能装6只鸡蛋的篮子!是不是很简单呢
数组也是这样的
将篮子看做为一个长度为5的数组 其元素有 1 ,2 ,3 ,4 ,5
此时有一个元素 6 需要加入
则先新建一个长度为6的数组
然后将原来数组中的元素依次放入新建的数组
然后将元素 6 也放入其中
然后将原来的篮子标签撕下 给新的数组
将原数组的地址指向新数组
想必看到这里 ,思路应该没有问题了
代码实现如下:
1 public classMyArray {2 //定义一个初始长度为0的数组,用来缓存数据
3 private String[] src = new String[0];4 /**
5 * 保存数据的方法6 *@params 要保存的元素7 */
8 public voidadd(String s) {9 //定义一个新数组,长度是原数组的长度+1
10 String[] dest = new String[src.length+1];11 //将新元素放入最后一位
12 dest[src.length]=s;13 //将原先的数据对应下标放入新数组
14 for(int i = 0 ;i
17 }18 //将原数组指向新数组
19 src=dest;20 }21 /**
22 * 根据下标提取元素的方法23 *@paramIndex 要提取元素的下标24 *@return返回所提取的元素25 */
26 public String get(intindex) {27 //返回对应下标的元素
28 returnsrc[index];29 }30
31 /**
32 * 获得元素可变数组中元素的个数[长度]33 *@return返回元素的个数34 */
35 public intsize() {36 //返回数组的长度
37 returnsrc.length;38 }39 /**
40 * 将新元素插入到指定位置41 *@params 要插入的新元素42 *@paramindex 要插入的位置43 */
44 public void insert(String s,intindex) {45 //创建一个新的数组,其长度为原数组长度加1
46 String[] dest = new String[src.length+1];47 //将指定的元素放入指定的位置
48 dest[index]=s;49 //在指定下标之前的元素对应下标放入新数组
50 for(int i=0;i
54 for(int i=index+1;i
60 * 删除指定未知的元素61 *@paramindex 要删除的元素的下标62 */
63
64 public void delete(intindex) {65 //创建一个新的数组,其长度为原数组长度减1
66 String[] dest = new String[src.length-1];67 //指定下标之前的原数组元素对应其下标位置放入新数组
68 for(int i=0;i
72 for(int i=index+1;i
78 /**
79 * 将指定位置的元素与指定元素替换80 *@paramindex 指定位置的下标81 *@params 要替换的元素82 *@return返回替换后的83 */
84
85 public String replace (intindex,String s) {86 return src[index]=s;87 }88 }
感谢阅读