java数组

简介: 数组数组简介数组概念 数组是存储同一种数据类型多个元素的集合。也可以看成是一个容器。数组既可以存储基本数据类型,也可以存储引用数据类型。为什么要有数组(容器)为了存储同种数据类型的多个值数组定义格式   数据类型[] 数组名 = new 数...

数组

数组简介

  • 数组概念
    • 数组是存储同一种数据类型多个元素的集合。也可以看成是一个容器。
    • 数组既可以存储基本数据类型,也可以存储引用数据类型。
  • 为什么要有数组(容器)

    • 为了存储同种数据类型的多个值
  • 数组定义格式
      数据类型[] 数组名 = new 数据类型[数组的长度];

数组的初始化动态初始化

  • 1:什么是数组的初始化
    • 就是为数组开辟连续的内存空间,并为每个数组元素赋予值
  • 2:如何对数组进行初始化
    • a:动态初始化 只指定长度,由系统给出初始化值
      • int[] arr = new int[5];
    • b:静态初始化 给出初始化值,由系统决定长度
  • 3:动态初始化的格式

    • 初始化有三种方法
    • 数据类型[] 数组名 = new 数据类型[数组长度];

    • 数据类型[] 数组名=new 数据类型{元素一,元素二,元素三···}

    • 数据类型[] 数组名=new 数据类型[]{元素一,元素二,元素三···}

二维数组

  注:平常实现的二维数组只是元素是一维数组的一维数组,而数组也是引用类型,继承自Object类。数组是new出来的。这些性质也就导致arraycopy()二维数组时出现的问题。
* 二维数组格式1
* 数据类型 数组名[][] = new 数据类型[m][n];
* 数据类型[] 数组名[] = new 数据类型[m][n];
* 例:int[][] arr = new int[3][2];
int[] arr[] = new int[3][2];

  • 二维数组格式2

    • 数据类型 数组名[][] = new 数据类型[m][]
    • 例:int[][] arr = new int[3][];
  • 二维数组格式3

    • 数据类型 数组名[][] = new {{元素一,元素二···},{元素一,元素二···},{元素一,元素二···}···}
    • 例: int[][] arr = {{1,2,3},{4,5},{6,7,8,9}};

数组常用的一些方法

数组的复制

  • public static native void arraycopy(Object src, int srcPos, Object dest, int destPos, int length);
      复制指定源数组src到目标数组dest。复制从src的srcPos索引开始,复制的个数是length,复制到dest的索引从destPos开始。
      如果是数组比较大,那么使用System.arraycopy会比较有优势,因为其使用的是内存复制,省去了大量的数组寻址访问等时间

  • int[] copyOf(int[] original, int newLength)
      复制数组,指定新数组长度
      注:数组扩容的实现

    int[] a=new int[3];
    a=Arrays.copyOf(a,a.length+1);
  • int[] copyOfRange(int[] original, int from, int to)
      复制数组,指定所复制的原数组的索引
    int[] arr6 = {1, 2, 3, 4, 5};
    int[] arr7 = Arrays.copyOf(arr6, 5); // 1 2 3 4 5
    int[] arr8 = Arrays.copyOfRange(arr6, 1, 3); // 2 3
    for (int x: arr7) {
      System.out.print(x + "\t");
    }
    System.out.println();
    for (int x: arr8) {
      System.out.print(x + "\t");
    }
    System.out.println();

数组的排序

  • public static void sort(int[] a)
    对指定的 int 型数组按数字升序进行排序。该排序算法是一个经过调优的快速排序法

  • public static void sort(double[] a,int fromIndex,int toIndex)
    指定 short 型数组的指定范围按数字升序进行排序。
    排序的范围从索引 fromIndex(包括)一直到索引 toIndex(不包括)。(如果 fromIndex==toIndex,则排序范围为空。)

例:

int[] arr4 = {3, 7, 2, 1, 9};
    Arrays.sort(arr4);
    for (int x: arr4) {
      System.out.print(x + "\t"); // 1 2 3 7 9
    }
    System.out.println();
    int[] arr5 = {3, 7, 2, 1, 9};
    Arrays.sort(arr5, 1, 3);
    for (int x: arr5) {
      System.out.print(x + "\t"); // 3 2 7 1 9
    }
    System.out.println();

Arrays.fill()填充数组

使用Arrays类的静态方法,需要import包java.util.Arrays,定义了许多重载方法。

  • void fill(int[] a, int val)  全部填充

  • void fill(int[] a, int fromIndex, int toIndex, int val)
    填充指定索引的元素

例:

    int[] arr3 = new int[5];
    for (int x: arr3) {
      System.out.print(x + "\t"); // 0 0 0 0 0 全部初始化为0
    }
    System.out.println();
    Arrays.fill(arr3, 10);
    for (int x: arr3) {
      System.out.print(x + "\t"); // 10 10 10 10 10 全部填充为10
    }
    System.out.println();
    Arrays.fill(arr3, 1, 3, 8);
    for (int x: arr3) {
      System.out.print(x + "\t"); // 10 8 8 10 10 填充指定索引
    }
    System.out.println();

连接两个数组(合并)

ArrayUtils是Apache提供的数组处理类库,其addAll方法可以很方便地将两个数组连接成一个数组。

int[] intArray = { 1, 2, 3, 4, 5 };
int[] intArray2 = { 6, 7, 8, 9, 10 };
// Apache Commons Lang library
int[] combinedIntArray = ArrayUtils.addAll(intArray, intArray2);

数组翻转

reverse:将一个数组翻转

int[] intArray = { 1, 2, 3, 4, 5 };
ArrayUtils.reverse(intArray);
System.out.println(Arrays.toString(intArray));//[5, 4, 3, 2, 1]

数组是否包含某个元素(了解)

方法1:
Arrays.toString(s2).contains 转化为字符串,然后用contain方法

/*3.数组是否包含某个元素,用Arrays.toString(s2),然后直接用字符串.contain方法*/
        System.out.println("字符串是否包含:" + Arrays.toString(s2).contains("wyx"));

方法2:转化为集合,然后用contain方法

 /*将数组转化为ArrayList  Arrays.asList(数组)   */
        List<String> list = new ArrayList<>(Arrays.asList(s2));
        list.add("whh");
        System.out.println("ArrayList是否包含:" + list.contains("whh"));
/*转化为set*/
 Set<String> set = new HashSet<>(Arrays.asList(s2));
        System.out.println("集合set是否包含:" + set.contains("wyy"));

方法3:自循环

public static boolean Loop(String[] arr, String targetValue) {
        for(String s: arr){
            if(s.equals(targetValue))
                return true;
        }
        return false;
    }

数组的面试题

数组求和

  给定一个含有n个元素的整型数组a,求a中所有元素的和。(要求用递归法,只用一行代码)

 分析

  1. 如果数组元素个数为0,那么和为0。

  2. 如果数组元素个数为n,那么先求出前n - 1个元素之和,再加上a[n - 1]即可

// 数组求和
int sum(int[] a, int n)
{
     return n == 0 ? 0 : sum(a, n -1) + a[n -1];
}

length(),length

  •  数组的长度则用到了length这个属性

  •  想看这个字符串的长度则用到length()这个方法.

  •  针对泛型集合说的,如果想看这个泛型有多少个元素,用size()方法

分析
  数组是一个容器对象,其中包含固定数量的同一类型的值。一旦数组被创建,他的长度就是固定的了。数组的长度可以作为final实例变量的长度。因此,长度可以被视为一个数组的属性。
  String背后的数据结构是一个char数组,所以没有必要来定义一个不必要的属性(因为该属性在char数值中已经提供了),所以用length()这个方法。

相关文章
|
3月前
|
存储 缓存 算法
Java 数组
【10月更文挑战第19天】Java 数组是一种非常实用的数据结构,它为我们提供了一种简单而有效的方式来存储和管理数据。通过合理地使用数组,我们能够提高程序的运行效率和代码的可读性。更加深入地了解和掌握 Java 数组的特性和应用,为我们的编程之旅增添更多的精彩。
41 4
|
3月前
|
存储 缓存 算法
提高 Java 数组性能的方法
【10月更文挑战第19天】深入探讨了提高 Java 数组性能的多种方法。通过合理运用这些策略,我们可以在处理数组时获得更好的性能表现,提升程序的运行效率。
48 2
|
3月前
|
存储 Java
Java“(array) <X> Not Initialized” (数组未初始化)错误解决
在Java中,遇到“(array) &lt;X&gt; Not Initialized”(数组未初始化)错误时,表示数组变量已被声明但尚未初始化。解决方法是在使用数组之前,通过指定数组的大小和类型来初始化数组,例如:`int[] arr = new int[5];` 或 `String[] strArr = new String[10];`。
108 2
|
3月前
|
存储 Java
什么是带有示例的 Java 中的交错数组?
什么是带有示例的 Java 中的交错数组?
62 9
|
3月前
|
Java
Java数组动态扩容和动态缩减
Java数组动态扩容和动态缩减
30 3
|
3月前
|
存储 算法 Java
Java一分钟之-数组的创建与遍历
数组作为Java中存储和操作一组相同类型数据的基本结构,其创建和遍历是编程基础中的基础。通过不同的创建方式,可以根据实际需求灵活地初始化数组。而选择合适的遍历方法,则可以提高代码的可读性和效率。掌握这些基本技能,对于深入学习Java乃至其他编程语言的数据结构和算法都是至关重要的。
35 6
|
3月前
|
存储 Java 程序员
【一步一步了解Java系列】:何为数组,何为引用类型
【一步一步了解Java系列】:何为数组,何为引用类型
39 1
|
3月前
|
存储 XML Java
如何在 Java 中将常见文档转换为 PNG 图像数组
如何在 Java 中将常见文档转换为 PNG 图像数组
23 1
|
3月前
|
存储 安全 Java
Java数组(Arrays)详解
Java 中的数组是一种用于存储固定数量同类型数据的高效数据结构,支持连续内存存储和随机访问。数组可以声明并初始化,通过索引访问和修改元素,获取长度,使用循环遍历,支持多维形式,并可通过 `Arrays` 类的方法进行复制和排序。数组具有固定大小和类型安全的特点,但需注意越界等问题。灵活运用数组能显著提升编程效率。
148 9
|
4月前
|
存储 Java 数据处理
Java 数组的高级用法
在 Java 中,数组不仅可以存储同类型的数据,还支持多种高级用法,如多维数组(常用于矩阵)、动态创建数组、克隆数组、使用 `java.util.Arrays` 进行排序和搜索、与集合相互转换、增强 for 循环遍历、匿名数组传递以及利用 `Arrays.equals()` 比较数组内容。这些技巧能提升代码的灵活性和可读性,适用于更复杂的数据处理场景。
47 10