当前位置:首页 > 行业动态 > 正文

string数组去重的几种方法

本文介绍了几种常用的string数组去重方法,包括使用HashSet、排序后去除重复元素等。

在编程中,我们经常会遇到需要对字符串数组进行去重的情况,这是因为在某些情况下,我们不希望数组中存在重复的元素,如何对字符串数组进行去重呢?本文将介绍几种常见的方法。

1、使用HashSet

HashSet是Java中的一个集合类,它不允许集合中有重复的元素,我们可以将字符串数组转换为HashSet,然后再转换回数组,这样就可以实现去重。

import java.util.Arrays;
import java.util.HashSet;
public class Main {
    public static void main(String[] args) {
        String[] arr = {"apple", "banana", "apple", "orange"};
        HashSet<String> set = new HashSet<>(Arrays.asList(arr));
        String[] result = set.toArray(new String[0]);
        System.out.println(Arrays.toString(result));
    }
}

2、使用双重循环

双重循环是一种简单的去重方法,通过两层循环遍历数组,如果发现有重复的元素,就将其删除,但是这种方法的时间复杂度较高,不适用于大规模的数据。

public class Main {
    public static void main(String[] args) {
        String[] arr = {"apple", "banana", "apple", "orange"};
        for (int i = 0; i < arr.length; i++) {
            for (int j = i + 1; j < arr.length; j++) {
                if (arr[i].equals(arr[j])) {
                    arr[j] = arr[arr.length 1];
                    arr = Arrays.copyOf(arr, arr.length 1);
                    j--;
                }
            }
        }
        System.out.println(Arrays.toString(arr));
    }
}

3、使用Stream API

Java 8引入了Stream API,它提供了一种简洁的数据处理方式,我们可以使用Stream的distinct方法对字符串数组进行去重。

import java.util.Arrays;
import java.util.stream.Stream;
public class Main {
    public static void main(String[] args) {
        String[] arr = {"apple", "banana", "apple", "orange"};
        String[] result = Stream.of(arr).distinct().toArray(String[]::new);
        System.out.println(Arrays.toString(result));
    }
}

4、使用LinkedHashSet

LinkedHashSet是HashSet的一个子类,它保留了元素的插入顺序,我们可以先将字符串数组转换为LinkedHashSet,然后再转换回数组,这样就可以实现去重并保留原来的顺序。

import java.util.Arrays;
import java.util.LinkedHashSet;
import java.util.Set;
public class Main {
    public static void main(String[] args) {
        String[] arr = {"apple", "banana", "apple", "orange"};
        Set<String> set = new LinkedHashSet<>(Arrays.asList(arr));
        String[] result = set.toArray(new String[0]);
        System.out.println(Arrays.toString(result));
    }
}

以上就是对字符串数组进行去重的四种常见方法,每种方法都有其优点和缺点,具体使用哪种方法,需要根据实际情况来决定。

0

随机文章