剑指offer——最小的k个数(数组:ArrayList类)

剑指offer——最小的k个数(数组:ArrayList类)

1 必备知识点:

首先要熟悉Java从入门到精通——数组+foreach

2 ArrayList简介

ArrayList:动态数组,是Array的复杂版本,它提供了如下一些好处:

  1. 动态的增加和减少元素
  2. 实现了ICollection和IList接口
  3. 灵活的设置数组的大小

一个不错的总结: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删除元素
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值