003.数组扩容

1.代码

package com.suanfa.demo;

public class A {
    private int[] data;
    private int length = 0;
    int j = 0;

    public A() {
        data = new int[5];
    }

    //插入元素
    public void insert(int x) {
        expand();
        data[length++] = x;
    }

    //显示元素
    public void show() {
        for (int i = 0; i < length; i++) {
            System.out.print(data[i] + "****");
        }
        System.out.println();
    }

    //对元素扩容
    public void expand() {
        //todo 完成数组的扩容代码
        if (length >= data.length / 2) {
            j++;
            int[] temp = data;
            data = new int[data.length * 2];
            /**
             * 遍历时参数的选择
             * 1.data.length   会报越界
             * 2.temp.length    旧的数组不一定会装满,没必要去遍历后面的元素
             */
            for (int i = 0; i < temp.length; i++) {
                data[i] = temp[i];
            }
            System.out.println("数组第"+j+"次扩容");
        }
    }

}
package com.suanfa.demo;

public class B {
    public static void main(String[] args) {
        A a = new A();
        a.insert(0);
        a.insert(1);
        a.insert(2);
        a.show();
        a.insert(3);
        a.insert(4);
        a.insert(5);
        a.show();
        a.insert(6);
        a.insert(7);
        a.insert(8);
        a.insert(9);
        a.insert(10);
        a.insert(11);
        a.show();
    }
}

2.充满回忆的一行代码

 

posted @ 2022-04-28 17:52  李林林  阅读(27)  评论(0编辑  收藏  举报