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

createh54个月前 (02-01)技术教程63

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

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 有序数组)

有序数组的平方题目描述:给定一个按非递减顺序排序的整数数组 nums,返回每个数字的平方组成的新数组,要求也按非递减顺序排序。示例:输入: nums = [-4,-1,0,3,10] 输出: [0,1...

Java数组详解(java数组操作方法)

数组,也叫Array,是由同一种数据类型按照一定的顺序排列的集合,给这个数组起一个名字。是一种数据类型。定义数组,在类型的后面加一个[]定义数组有两种方式①静态初始化 int[] num=new in...

全新Java入门到架构师教程之Java15数组案例实现和Arrays

上篇文章写了《全新Java入门到架构师课程之Java15编程基础-数组(1):数组声明、初始化、数组元素的界限和遍历》,这次将接下去说java15编程之数组案例实现和Arrays一、数组基本练习//A...

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

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

从零开始学Java-006-二维数组(java二维数组的用法)

二维数组二维数组是一种特殊形式的一维数组,二维数组的每一个元素都是一个一维数组声明数组和一维数组一样,在使用数组之前,要先定义数组所属的数据类型,即声明二维数组。声明二维数组一共有两种语法格式。第1种...