请关注本人博文——《详解 普通数组 —— Arrays类 与 浅克隆》

Arrays类:

概述:

针对数组进行操作的工具类。它提供了对于数组的值的排序、查找等功能。

现在,本人来展示一下Arrays类的常用API

  • public static List asList(T... a)

    返回一个受指定数组支持的固定大小的列表。
  • public static String toString(int[] a)
  • public static void sort(int[] a)
  • public static int binarySearch(int[] a,int key)

    这个方法的底层实现,就运用了二分查找的原理
  • static boolean equals(int[] a, int[] a2)

    比较两个数组中的元素,是否一样
  • static int[] copyOf(int[] original, int newLength)

    复制旧数组中的元素到一个新的数组中,新的数组长度是newLength 从0开始复制旧数组
  • static int[] copyOfRange(int[] original, int from, int to)

    复制旧数组中的指定范围间的几个元素到新数组中

现在,本人来展示下Arrays类的其余API

  • static void sort(八大基本类型[] a)

    对指定的 该数组按数字升序进行排序。
  • static void sort(Object[] a, int fromIndex, int toIndex)

    根据元素的自然顺序对指定对象数组的指定范围按升序进行排序。
  • static < T > List< T > asList(T... a)

    返回一个受指定数组支持的固定大小的列表。
  • static int binarySearch(八大基本类型[] a, 八大基本类型 key)

    使用二分搜索法来搜索指定数组,以获得指定的值。
  • static int binarySearch(八大基本类型[] a, int fromIndex, int toIndex, 八大基本类型 key)

    使用二分搜索法来搜索指定数组的范围,以获得指定的值。
  • static 八大基本类型[] copyOf(八大基本类型[] original, int newLength)

    复制指定的数组,截取或用 0 填充(如有必要),以使副本具有指定的长度。
  • static T[] copyOf(T[] original, int newLength)

    复制指定的数组,截取或用 null 填充(如有必要),以使副本具有指定的长度。
  • static <T,U> T[] copyOf(U[] original, int newLength, Class<? extends T[]> newType)

    复制指定的数组,截取或用 null 填充(如有必要),以使副本具有指定的长度。
  • static <T,U> T[] copyOf(U[] original, int newLength, Class<? extends T[]> newType)

    复制指定的数组,截取或用 null 填充(如有必要),以使副本具有指定的长度。
  • static 八大基本类型[] copyOfRange(八大基本类型[] original, int from, int to)

    将指定数组的指定范围复制到一个新数组。
  • static T[] copyOfRange(T[] original, int from, int to)

    将指定数组的指定范围复制到一个新数组。
  • static <T,U> T[] copyOfRange(U[] original, int from, int to, Class<? extends T[]> newType)

    将指定数组的指定范围复制到一个新数组。
  • static boolean equals(Object[] a, Object[] a2)

    如果两个指定的 Object[] 型数组彼此相等,则返回 true。
  • static String toString(八大基本类型[] a)

    返回指定数组内容的字符串表示形式。

至于排序,在本人的《数据结构与算法》专栏中已经详细的讲解过了,所以,在这里,本人来介绍一下针对数组的查找手段——二分查找

二分查找:

二分查找是有前提的:

前提

数组已经排序好

二分查找的思想是:

思想

将数组分为两半,让要目标值 与 中间的值作比较,比中间数大的话,就在中间数左边的序列中再这样查找;反之则在中间数右边的序列中这样查找

现在,我们来用代码简单实现下 二分查找:

private static int getIndex(int[] arr, int num) {
//定义三个索引
int minIndex = 0;
int maxIndex = arr.length - 1;
int centIndex = (minIndex + maxIndex) / 2;
while (minIndex <= maxIndex) {
if (num == arr[centIndex]) {
return centIndex;
} else if (num < arr[centIndex]) {
maxIndex = centIndex - 1;
} else if (num > arr[centIndex]) {
minIndex = centIndex + 1;
}
//重新计算中间索引
centIndex = (minIndex + maxIndex) / 2;
}
return -1;
}

那么,本人在这里展示下Arrays类的使用:

package about_arrays;

import java.util.Arrays;
import java.util.List; public class Test { public static void main(String[] args) {
int[] array = new int[] {1, 3, 5, 7, 9, 11}; List<Integer> list = Arrays.asList(1, 2, 5, 3, 4); for (int i = 0; i < list.size(); i++) {
System.out.println(list.get(i));
} int position = Arrays.binarySearch(array, 7);
System.out.println("7在array数组中的下标为:" + position);
} }

那么,本人来展示下运行结果:

至于List,将在本人博文——《详解 List接口》讲到,希望大家多多支持!!!

(本人普通数组总集篇博文链接:https://www.cnblogs.com/codderYouzg/p/12416481.html

详解 Arrays类的更多相关文章

  1. unity3D游戏开发之详解Animation类和Animator类

    详解Animator类和Animation类 链接: http://wenku.baidu.com/link?url=SiaUYcdrNYjOYrWVDJSKGAYdJOntMTOhsVJtyBk2i ...

  2. 【python进阶】详解元类及其应用1

    前言 元类在python中是很重要的一部分,我将分两次去讲解元类及其应用,此篇为详解元类及其应用第一篇,下面开始今天的说明~~~ 1. 类也是对象 在⼤多数编程语⾔中,类就是⼀组⽤来描述如何⽣成⼀个对 ...

  3. 【python进阶】详解元类及其应用2

    前言 在上一篇文章[python进阶]详解元类及其应用1中,我们提到了关于元类的一些前置知识,介绍了类对象,动态创建类,使用type创建类,这一节我们将继续接着上文来讲~~~ 5.使⽤type创建带有 ...

  4. Unity3D - 详解Quaternion类(二)

    OK,不做引子了,接上篇Unity3D - 详解Quaternion类(一)走起! 四.Quaternion类静态方法 Quaternion中的静态方法有9个即:Angle方法.Dot方法.Euler ...

  5. Unity3D - 详解Quaternion类(一)

    一.简介 Quaternion又称四元数,由x,y,z和w这四个分量组成,是由爱尔兰数学家威廉·卢云·哈密顿在1843年发现的数学概念.四元数的乘法不符合交换律.从明确地角度而言,四元数是复数的不可交 ...

  6. Kotlin——最详解的类(class)的使用

    在任何一门面向对象编程的语言里,类(class)是非常基础.但也是非常重要的一项组成,通俗的说就是万般皆对象,而所说的对象就是我们生成的类.Kotlin也是如此,下面详细为大家介绍Kotlin中的类的 ...

  7. IOC和AOP使用扩展之AOP详解实现类

    摘要:   “Depend on yourself” is what nature says to every man.  Parents can help you. Teachers can hel ...

  8. 详解 Collections类

    (请关注 本人"集合总集篇"博文--<详解 集合框架>) 有的同学可能会有这样的疑问 -- Collections类也是集合吗? 答曰:非也! 那为什么要讲解这个类呢? ...

  9. 详解 Paths类 与 Files类

    在本篇博文中,本人主要讲解NIO 的两个核心点 -- 缓冲区(Buffer) 和 通道 (Channel)之一的 缓冲区(Buffer), 有关NIO流的其他知识点请观看本人博文<详解 NIO流 ...

随机推荐

  1. 《JavaScript 模式》读书笔记(5)— 对象创建模式4

    我们学完了大部分对象创建模式相关的内容,下面还有一些小而精的部分. 七.对象常量 JavaScript中没有常量的概念,虽然许多现代的编程环境可能为您提供了用以创建常量的const语句.作为一种变通方 ...

  2. HDU - 1962 二分图最大匹配模板(扑克牌得分最大)

    题意: 直接说数据,第一行给定几组数据,每一组数据的第一行是两个人扑克牌分别的数量,第一行是亚当的扑克牌,第二行是夏娃的扑克牌,每一个扑克牌的大小用两个字符来表示,第一个表示是几号扑克牌,第二个表示扑 ...

  3. Jmeter接口测试之用户自定义变量(九)

    在使用Jmeter做接口自动化测试中,经常会使用到公共的数据,那么就需要对这些公共的数据分离出来,不管是基于测试框架的思想,还是使用工具来进行做自动化测试,公共数据的分离首先是需要思考的.这里就以获取 ...

  4. 用FME处理物探点表和线表,生成管线和设施

    在项目的数据处理中,客户会提供物探点表和线表. 点表主要包括该点的物探编号.该点的X坐标.Y坐标.点的其他属性 线表主要包括该线的起始点物探编号.终止物探编号.线的其他属性 点表

  5. MySql查询当天、本周、本月、本季度、本年的数据

    1.今天 SELECT * FROM 表名 WHERE TO_DAYS(时间字段名) = TO_DAYS(NOW()); 2.昨天 ; 3.本周 SELECT * FROM 表名 WHERE YEAR ...

  6. 看完这篇Exception 和 Error,和面试官扯皮就没问题了

    在 Java 中的基本理念是 结构不佳的代码不能运行,发现错误的理想时期是在编译期间,因为你不用运行程序,只是凭借着对 Java 基本理念的理解就能发现问题.但是编译期并不能找出所有的问题,有一些 N ...

  7. SVN同步代码问题集锦

    1.删除文件后file missing警告                      相关链接: http://blog.sina.com.cn/s/blog_63e26d560100ve00.htm ...

  8. Unity引擎入门——制作第一个2D游戏(2)角色移动与动画

    在上一节的内容里,我们已经创建出了一个主角,也搭建了一个简单的场景. 传送门:https://www.cnblogs.com/zny0222/p/12653088.html 既然有了主角,要怎样才能让 ...

  9. Java多线程工具类之循环栅栏计数器

    Java多线程下循环计数器 本文主要内容:CyclicBarrier(下文中凯哥就用cycBar来代替)定义介绍:举例说明:代码演示:从源码来看原理及总结:CyclicBarrier与CountDow ...

  10. Celery动态添加定时任务

    背景 业务需求:用户可创建多个多人任务,需要在任务截止时间前一天提醒所有参与者 技术选型: Celery:分布式任务队列.实现异步与定时 django-celery-beat:实现动态添加定时任务,即 ...