Java合并两个数组,以及数组排序并去重

createh53个月前 (02-01)技术教程31

还有其他的方法,这里我列出最简单的方法来实现。

1、Java合并两个数组

第一种:

public static void main(String[] args) {
        int[] a = new int[]{58, 64, 21, 0, 89, 31, 26};
        int[] b = new int[]{6, 7, 8};

        int[] c = new int[a.length + b.length];
        int i;
        for (i = 0; i < a.length; i++) {
            c[i] = a[i];
        }
        for (int j = 0; j < b.length; j++) {
            c[i + j] = b[j];
        }
        // 输出合并后的数组
        System.out.println(Arrays.toString(c));
}

输出结果:

第二种:

public static void main(String[] args) {
        // 两个待合并数组
        int array1[] = {20,10,50,40,30};
        int array2[] = {1,2,3};

        // 动态初始化数组,设置数组的长度是array1和array2长度之和
        int array[] = new int[array1.length + array2.length];

        // 循环添加数组内容
        for (int i = 0; i < array.length; i++) {

            if (i < array1.length) {
                array[i] = array1[i];
            } else {
                array[i] = array2[i - array1.length];
            }
        }

        System.out.println("合并后:");
        for (int element : array) {
            System.out.printf("%d ", element);
        }
}

输出结果:

2、Java数组排序并去重

public static void main(String[] args) {
         /*
        思路:
            1.hashset去重
            2.转成treeset排序
            3.转成integer数组
            4.转成int数组
            5.输出
         */

        Integer[] array = {1, 3, 4, 3, 2, 5, 6, 3, 9, 22};
        //去重
        HashSet hashset = new HashSet<>();

        for (int i = 0; i < array.length; i++) {
            hashset.add(array[i]);
        }

        //转成TreeSet排序
        TreeSet treeSet = new TreeSet<>(hashset);
        //转成integer数组
        Integer[] integers = treeSet.toArray(new Integer[]{});

        int[] ints = new int[integers.length];

        //foreach仅可用于遍历输出数组,但不能用于修改数组。
        for (int i = 0; i < integers.length; i++) {
            ints[i] = integers[i].intValue();
        }

				// 使用JDK1.8新特性输出
        Arrays.stream(ints).forEach(System.out::println);
}

输出结果:

相关文章

二十、Java数组(java数组的使用)

数组的基本概念数组是一种可以存储多个相同类型数据的数据结构,这些数据在内存中是连续存储的。数组中的每个数据项称为数组的元素,每个元素都可以通过索引来访问。Java中的数组属于对象类型,数组中的可以是基...

DJL 之 Java 玩转多维数组,就像 NumPy 一样

本文适合有 Java 基础的人群作者:DJL-LankingHelloGitHub 推出的《讲解开源项目》系列。有幸邀请到了亚马逊 + Apache 的工程师:Lanking( https://git...

趣味玩转数组:Java中的数组遍历技巧

当涉及到Java语言中的数组遍历和操作,我们可以从基本概念开始,逐步深入,以确保您理解得更全面。我们将覆盖以下主题:数组的基本概念声明和初始化数组数组的遍历常见的数组操作让我们一步一步来讲解这些内容:...

java数组的初始化及遍历(java数组元素初始化)

/*** 测试数组的三种初始化 以及遍历的两种方式* 静态初始化 动态初始化 默认初始化*/public class Test3 { private int id; private int age;...

刷题力扣349-两个数组的交集(两个数组的交集 ii)

这道题代码随想录用的是哈希数据结构,什么时候用哈希表,哈希表都是用来快速判断一个元素是否出现在集合里,相对于枚举的话,哈希表的时间复杂度只有O(1)。常见的三种哈希结构数组set(集合)map(映射)...