A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© mengxiang1993 中级黑马   /  2015-1-28 11:02  /  887 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

package ArrayList;

import java.util.Arrays;

public class SequenceList<T> {

        /**
         * 步骤 1:提供以默认数组长度创建空顺序表的构造方法 2.提供以一个初始化元素创建顺序表的构造方法
         * 3.提供指定顺序表中第一个元素,和指定数组长度来创建顺序表的构造方法 4.获取顺序线性表的大小方法 5.获取顺序线性表中索引为i处元素的方法
         * 6.查找顺序线性表中指定元素的索引 7.向顺序线性表指定位置插入一个元素 8.在顺序线性表的开始处添加一个元素
         * 9.删除顺序线性表中指定索引处的元素 10.删除顺序线性表中最后一个元素 11.判断顺序线性表是否为空 12.清空线性表13.返回顺序表大小
         *
         */
        // 默认数组长度
        private final int DEFAULT_SIZE = 16;
        // 保存数组的长度
        private int alength;
        // 定义数组用来保存List中的原色
        private Object[] b;
        // 线性表中元素的当前个数
        private int size = 0;

        // 1.提供以默认数组长度创建空顺序表的构造方法
        public SequenceList() {
                alength = DEFAULT_SIZE;
                b = new Object[alength];

        }

        // 2.提供以一个初始化元素创建顺序表的构造方法
        public SequenceList(T element) {
                this();
                b[0] = element;
                size++;
        }

        // 3.提供指定顺序表中第一个元素,和指定数组长度来创建顺序表的构造方法

        public SequenceList(T element, int initSize) {
                if (initSize < 0) {
                        throw new IllegalArgumentException("指定长度不能小于0");
                }
                b = new Object[initSize];
                b[0] = element;
                size++;

        }

        // 4.获取顺序线性表的大小方法
        public int getLength() {

                return size;
        }

        // 5.获取顺序线性表中索引为i处元素的方法
        public Object get(int i) {
                if (i < 0 || i > size - 1) {
                        throw new IndexOutOfBoundsException("线性表索引越界");
                }

                return b[i];

        }

        // 6.查找顺序线性表中指定元素的索引
        public int getIndexOf(T element) {
                for (int i = 0; i < b.length; i++) {
                        if (element.equals(b[i]))
                                return i;

                }

                return -1;
        }

        // 7.向顺序线性表指定位置插入一个元素
        public void insert(T element, int index) {
                if (index < 0 || index > size) {
                        throw new IndexOutOfBoundsException("线性表索引越界");
                }

                while (alength < size + 1) {
                        alength <<= 1;
                }
                b = Arrays.copyOf(b, alength);

                System.arraycopy(b, index, b, index + 1, size - index);
                /*
                 * for (int i = 0; i < b.length; i++) { System.out.print(b[i]); }
                 */
                b[index] = element;
                size++;

        }

        // 8.在顺序线性表的开始处添加一个元素
        public void add(T element) {
                insert(element, size);
        }

        // 9.删除顺序线性表中指定索引处的元素
        public T delete(int index) {
                if (index < 0 || index > size) {
                        throw new IndexOutOfBoundsException("线性表索引越界");
                }
                size--;
                T oldvalue = (T) b[index];
                System.arraycopy(b, index + 1, b, index, size - index);
                // 清空顺序表最后一个元素
                b[size] = null;
                /*
                 * for (int i = 0; i < b.length; i++) { System.out.println(b[i]); }
                 */
                return oldvalue;

        }

        // 10.删除顺序线性表中最后一个元素
        public T removeLast() {
                return (T) b[size - 1];
        }

        // 11.判断顺序线性表是否为空
        public boolean empty() {
                return size == 0;
        }

        // 12.清空线性表
        public void clear() {
                // 将数组索引元素赋值为null
                for (int i = 0; i < size; i++) {
                        b[i] = null;
                }

                size = 0;

        }

        // 13.返回顺序表大小
        public int size() {
                return size;
        }

        // 14.toString()漂亮处理输出顺序列表元素

        public String toString() {
                StringBuffer sb = new StringBuffer("");
                if (size == 0) {
                        sb.append("[]");
                } else
                        for (int i = 0; i < size - 1; i++) {
                                sb.append("[");
                                sb.append(b[i] + ",");

                        }
                sb.append(b[size - 1] + "]");

                return sb.toString();

        }

}


0 个回复

您需要登录后才可以回帖 登录 | 加入黑马