数组是静态的,一个数组实例具有固定的大小,一旦创建了就无法改变容量了。而集合是可以动态扩展容量,可以根据需要动态改变大小,集合提供更多的成员方法,能满足更多的需求。
List list;//正确,list = null;
List list = new List();//是错误的用法 这是错误的!!!!!
List list = new ArrayList();这句创建了一个ArrayList实现类的对象后把它上溯到了List接口。此时它就是一个List对
象了,它有些ArrayList类具有的,但是List接口没有的属性和方法,它就不能再用了。 而ArrayList list=newArrayList();
创建一对象则保留了ArrayList的所有属性和方法。
Collection
├List
│├LinkedList
│├ArrayList
│└Vector
│ └Stack
└Set
Map
├Hashtable
├HashMap
└WeakHashMap
Collection是最基本的集合接口,一个Collection代表一组Object,即Collection的元素(Elements)。Java SDK不提供直接继承自Collection的类,Java SDK提供的类都是继承自Collection的“子接口”如List和Set。
所有实现Collection接口的类都必须提供两个标准的构造函数:无参数的构造函数用于创建一个空的Collection,有一个 Collection参数的构造函数用于创建一个新的Collection,这个新的Collection与传入的Collection有相同的元素。后一个构造函数允许用户复制一个Collection。
如何遍历Collection中的每一个元素?不论Collection的实际类型如何,它都支持一个iterator()的方法,该方法返回一个迭代子,使用该迭代子即可逐一访问Collection中每一个元素。典型的用法如下:
Iterator it = collection.iterator(); // 获得一个迭代子
while(it.hasNext()) {
Object obj = it.next(); // 得到下一个元素
}
import java.util.*;
public class SetExample {
public static void main(String args[]) {
Set set = new HashSet();
set.add("Bernadine");
set.add("Elizabeth");
set.add("Gene");
set.add("Elizabeth");
set.add("Clara");
System.out.println(set);
Set sortedSet = new TreeSet(set);
System.out.println(sortedSet);
}
}
运行程序产生了以下输出。请注意重复的条目只出现了一次,列表的第二次输出已按字母顺序排序。
[Gene, Clara, Bernadine, Elizabeth]
[Bernadine, Clara, Elizabeth, Gene]
ArrayList
,其优点在于随机访问元素,另一种是更强大的LinkedList
,它并不是为快速随机访问设计的,而是具有一套更通用的方法。ListIterator
,使用它可以从两个方向遍历List,也可以从List中间插入和移除元素。ListIterator
只应该用来由后向前遍历ArrayList,而不是用来插入和移除元素。因为那比LinkedList
开销要大很多。
//添加
ArrayList<Integer> list2 = new ArrayList<Integer>();
list2.add(12);
list2.add(23);
list2.add(9);
// get max,min
int maxa = Collections.max(list2),mina = Collections.min(list2);
System.out.println("list2's max value is " + maxa);
System.out.println("list2's min value is " + mina);
list2's max value is 23
list2's min value is 9
System.out.println("whole list2 is "+list2);
whole list2 is [12, 23, 9]
//拷贝
ArrayList<Integer> list21 = new ArrayList<Integer>();
list21.addAll(list2);
System.out.println("list21:copy list2 is "+list21);//不变
Collections.sort(list2);
System.out.println("list2 sort is "+list2);
list2 sort is [9, 12, 23]
Collections.sort(list2,Collections.reverseOrder());
System.out.println("list2 descend sort is "+list2);
list2 descend sort is [23, 12, 9]
Collections.reverse(list21);
System.out.println("reverse list21 is "+list21);
reverse list21 is [9, 23, 12]
int idx = list2.indexOf(23);
System.out.println("list2 is "+list2+" and 23 locates :"+idx);
list2 is [23, 12, 9] and 23 locates :0
int sum = 0;
for (int i=0;i<list2.size();i++){
sum += list2.get(i);
}
System.out.println("list2 sum is "+sum);
//利用stream求和
List<Integer> ls = new ArrayList<Integer>();
ls.add(43);
ls.add(27);
int sum2 = ls.stream().mapToInt(a->a).sum();
System.out.println("sum is "+sum2);
list2 sum is 44
sum is 70
//在1位置插入一个88(like insert)
list2.add(1,88);
System.out.println("insert 88 at [1] and list2 is "+list2);
insert 88 at [1] and list2 is [23, 88, 12, 9]
list2.remove(1);
System.out.println("remove [1] and list2 is "+list2);
list2.remove(list2.size()-1);//删除末尾
System.out.println("remove the last and list2 is "+list2);
remove [1] and list2 is [23, 12, 9]
remove the last and list2 is [23, 12]
list2.add(0,23);
System.out.println("add 23 at [0] and list2 now is "+list2);
for (int i=0;i<list2.size();i++){
if (list2.get(i)==23){
list2.remove(i);
i--;
}
}
System.out.println("remove 23 and list2 is "+list2);
remove 23 and list2 is [12]
ArrayList<Integer> list3 = new ArrayList<Integer>();
list3.add(45);
list3.add(52);
list3.add(66);
System.out.println("list3 is "+list3);
System.out.println("list3[0:2] is "+list3.subList(0,2));
list3 is [45, 52, 66]
list3[0:2] is [45, 52]
import java.util.*;
class Solution {
public int[] twoSum(int[] nums, int target) {
ArrayList<Integer> re = new ArrayList<Integer>();
for (int i=0;i<nums.length;i++){
for (int j=i+1;j<nums.length;j++){
if (nums[i]+nums[j]==target){
re.add(i);
re.add(j);
}
}
}
int[] res = re.stream().mapToInt(Integer::valueOf).toArray();
return res;
}
// 调用
public static void main(String[] args){
int[] nums = {2,7,11,9};
int target = 9;
Solution s = new Solution();
int[] lst = s.twoSum(nums,target);
System.out.println(Arrays.toString(lst));
}
}
[0, 1]
版权说明 : 本文为转载文章, 版权归原作者所有 版权申明
原文链接 : https://blog.csdn.net/justleavel/article/details/121416947
内容来源于网络,如有侵权,请联系作者删除!
ArrayList
,其优点在于随机访问元素,另一种是更强大的LinkedList
,它并不是为快速随机访问设计的,而是具有一套更通用的方法。ListIterator
,使用它可以从两个方向遍历List,也可以从List中间插入和移除元素。ListIterator
只应该用来由后向前遍历ArrayList,而不是用来插入和移除元素。因为那比LinkedList
开销要大很多。