剑指offer——最小的k个数(数组:ArrayList类)
1 必备知识点:
2 ArrayList简介
ArrayList:动态数组,是Array的复杂版本,它提供了如下一些好处:
- 动态的增加和减少元素
- 实现了ICollection和IList接口
- 灵活的设置数组的大小
一个不错的总结:Java 集合系列03之 ArrayList详细介绍(源码解析)和使用示例
ArrayList 是一个数组队列,相当于 动态数组。与Java中的数组相比,它的容量能动态增长。它继承于AbstractList,实现了List, RandomAccess, Cloneable, java.io.Serializable这些接口。
- ArrayList 继承了AbstractList,实现了List。它是一个数组队列,提供了相关的添加、删除、修改、遍历等功能。
- ArrayList 实现了RandmoAccess接口,即提供了随机访问功能。RandmoAccess是java中用来被List实现,为List提供快速访问功能的。在ArrayList中,我们即可以通过元素的序号快速获取元素对象;这就是快速随机访问。稍后,我们会比较List的“快速随机访问”和“通过Iterator迭代器访问”的效率。
- ArrayList 实现了Cloneable接口,即覆盖了函数clone(),能被克隆。
- ArrayList 实现java.io.Serializable接口,这意味着ArrayList支持序列化,能通过序列化去传输。
和Vector不同,ArrayList中的操作不是线程安全的!所以,建议在单线程中才使用ArrayList,而在多线程中可以选择Vector或者CopyOnWriteArrayList。
3 ArrayList构造函数
// 默认构造函数
ArrayList()
// capacity是ArrayList的默认容量大小。
//当由于增加数据导致容量不足时,容量会添加上一次容量大小的一半。
ArrayList(int capacity)
// 创建一个包含collection的ArrayList
ArrayList(Collection<? extends E> collection)
4 ArrayList中的API
// Collection中定义的API
boolean add(E object)
boolean addAll(Collection<? extends E> collection)
void clear()
boolean contains(Object object)
boolean containsAll(Collection<?> collection)
boolean equals(Object object)
int hashCode()
boolean isEmpty()
Iterator<E> iterator()
boolean remove(Object object)
boolean removeAll(Collection<?> collection)
boolean retainAll(Collection<?> collection)
int size()
<T> T[] toArray(T[] array)
Object[] toArray()
// AbstractCollection中定义的API
void add(int location, E object)
boolean addAll(int location, Collection<? extends E> collection)
E get(int location)
int indexOf(Object object)
int lastIndexOf(Object object)
ListIterator<E> listIterator(int location)
ListIterator<E> listIterator()
E remove(int location)
E set(int location, E object)
List<E> subList(int start, int end)
// ArrayList新增的API
Object clone()
void ensureCapacity(int minimumCapacity)
void trimToSize()
void removeRange(int fromIndex, int toIndex)
5 题目描述
输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,。
6 我的解答
解题思路:
注意鲁棒性分析:若k大于数组大小,则直接返回空的ArrayList数组,注意一定不能直接返回false或者null,理由是函数返回值类型为ArrayList。
之后:对数组进行排序,然后将数组的前k个值赋给新的ArrayList数组,返回ArrayList数组。
import java.util.Arrays;
import java.util.ArrayList;
public class Solution {
public ArrayList<Integer> GetLeastNumbers_Solution(int [] input, int k) {
ArrayList<Integer> arraylist = new ArrayList<Integer>();
if(input==null || input.length<=0 || input.length<k){//一定要注意鲁棒性分析
return arraylist;
}
Arrays.sort(input);//对数组进行排序
for(int i=0;i<k;i++){
arraylist.add(input[i]);
}
return arraylist;
}
}
7扩展
百度经验:怎样区分ArrayLis和HashMap
ArrayList集合可以动态维护,访问元素时需要类型转换
ArrayList list=new ArrayList();
list.add();//按顺序添加元素
list.remove();//写下标或写元素删除你不需要的元素
list.set(1,M);//将下标为1的元素改成M
list.clear();//清空所有的元素
get.llist();里面写下标找到你要找的元素
HashMap的元素都是以键/值对的形式存在
不能通过索引访问元素,只能通过Key访问Value
HashMap engineers = new HashMap();
engineers.put(“ID”, “值”);//添加元素
String set= (String)engineers.get(“ID”);
System.out.println(set);//获取元素
engineers.remove(“ID");//通过key删除元素