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

createh55个月前 (02-01)技术教程78

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

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数组知识)

如果希望保存一组有相同类型的数据,可以使用数组。数组的定义和内存分配Java 中定义数组的语法有两种: type arrayName[]; type[] arrayName;type 为Java中的任...

灵魂拷问:如何检查 Java 数组中是否包含某个值?

作者 | 沉默王二责编 | Elle在逛 programcreek 的时候,我发现了一些专注细节但价值连城的主题。比如说:如何检查Java数组中是否包含某个值 ?像这类灵魂拷问的主题,非常值得深入地研...

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

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

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

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

java二维数组(java二维数组的行数和列数)

二维数组其实就是数组中的数组什么是数组中的数组,首先一维数组开辟了3格,但是3格在往下延伸了3格,就是我们的数组里面存储的并不是值,而是下一个数组的地址,等于就是数组中的数组,这就是二维数组的形式。如...

02《数据结构入门教程》数组(数据结构数组的基本操作)

1. 前言数组是一种重要的数据结构,可以利用它作为基础来实现很多复杂的数据结构。因此我们要深入理解数组的存储原理和特点,熟悉它的常用操作,重点掌握它在声明、查询、存储、复制等操作时的效率,便于我们在今...