写这篇文章的目的
最近在LeetCode上看一些算法题,有时候想自己写写看,但是一写就废,特别是能弄清楚原理后,关于数组的使用方法却总是出错,所以写下这篇文章,供自己和读者阅览。完全基于自己的理解,肯定会有不一样的想法,请包涵。话不多说,直接上代码!
代码
public class Application {
public static void main(String[] args) {
/**
* 1、列表实例化
*/
/**
* 探究List(有序的集合)\array(数组)\arrayList的区别
*/
//List是一个接口,所以不能被构造,只能通过“=null”的方式进行赋值,但不建议这样,因为null没有赋予空间,添加数据的时候会抛出空指针异常
List<Integer> list = null;
//ArrayList和 LinkedList 是List的impl层,可以视为List接口的常用实现类
//List list = new ArrayList();这句创建了一个ArrayList的对象后把上溯到了List
List<Integer> list1 = new ArrayList<>();
List<Integer> list2 = new LinkedList<>();
//为什么不用 ArrayList list = new ArrayList()?
//List 具有多个实现类,所以可以进行转换,而arrayList已经是实现类了,转换会有更多问题
/**
* 2、添加列表
*/
int a=1,b=2,c=3;
list1.add(a);
list1.add(b);
list2.add(c);
list2.add(1, c);// 将对象c添加到索引位置为1的位置
System.out.println(list1); //输出[1, 2]
System.out.println(list2); //输出[3, 3]
/*
* 3、修改列表
* */
list1.set(1, b);// 将索引位置为1的对象e修改为对象b
/*
* 4、切片
* */
List<Integer> listsub = list1.subList(0, 1);// 利用从索引位置 0 到 1(不包含) 的对象重新生成一个List集合
System.out.println(listsub); //输出[1]
/**
* 5、删除
*/
//通过索引删除
list1.remove(1);
System.out.println(list1); //输出[1]
/**
* 6、查询某一条数据
*/
System.out.println(list1.get(0)); //1
/*
* 1、实例化数组
* */
//数组array,array类是私有构造方法,所以不能采用new的实例化,可以通过静态方法调用
/*
* 数组array,若想要实例化,需要int[] nums = new int[5]的形式;但建议写成Integer[]的形式,
* 因为CRUD操作不能用array进行,而list不支持基本类型!!!
*/
int[] nums = new int[5];
Integer[] nums2 = {1,2,3,4,5};
Array.get(nums2,1);
/**
* 2、添加数组
*/
//数组一般来说已经确定了大小,所以int[]形式的数组添加数据需要转换成ArrayList!
List<Integer> newList = new ArrayList(Arrays.asList(nums2));
newList.add(1);
/*
* 3、修改数组
* */
newList.set(1, b);// 将索引位置为1的对象e修改为对象b
System.out.println(newList); //[1, 2, 3, 4, 5, 1]
/*
* 4、切片
* */
List<Integer> listsub2 = newList.subList(0, 1);// 利用从索引位置 0 到 1(不包含) 的对象重新生成一个List集合
System.out.println(listsub2); //[1]
/**
* 5、删除
*/
//通过索引删除
newList.remove(1);
System.out.println(newList);//[1, 3, 4, 5, 1]
/**
* 6、查询
*/
System.out.println(newList.get(0)); //1
}
}