java怎么去除数组中相同的数
在java中去除数组中的重复元素可以采用以下三种方法:1. 使用hashset将元素添加到集合、去除重复后转换回数组;2. 对数组排序后,使用双指针跳过重复元素;3. 使用hashmap存储元素并跟踪重复次数,再创建新数组存储不重复元素。
Java中去除数组中重复元素
在Java中去除数组中重复元素是一种常见操作。可以通过以下步骤实现:
1. 使用HashSet
HashSet是一个不包含重复元素的集合。我们可以将数组中的元素添加到HashSet中,然后再将其转换回数组。
int[] arr = {1, 2, 3, 4, 5, 1, 2, 3}; // 创建HashSet并添加数组元素 HashSet<Integer> set = new HashSet<>(); for (int num : arr) { set.add(num); } // 将HashSet转换为数组 int[] newArr = new int[set.size()]; int index = 0; for (Integer num : set) { newArr[index++] = num; }
2. 使用Arrays.sort()和双指针
我们可以对数组进行排序,然后使用双指针从左到右遍历数组。如果找到重复元素,则跳过它。
int[] arr = {1, 2, 3, 4, 5, 1, 2, 3}; // 排序数组 Arrays.sort(arr); int i = 0, j = 1; while (j < arr.length) { if (arr[i] != arr[j]) { arr[++i] = arr[j]; } j++; } // 调整数组大小 int[] newArr = Arrays.copyOf(arr, i + 1);
3. 使用HashMap
HashMap可以存储键值对。我们可以将数组中的元素作为键,并使用HashMap中的值来跟踪重复次数。
int[] arr = {1, 2, 3, 4, 5, 1, 2, 3}; // 创建HashMap并存储键值对 HashMap<Integer, Integer> map = new HashMap<>(); for (int num : arr) { map.put(num, map.getOrDefault(num, 0) + 1); } // 创建新数组并存储不重复元素 int[] newArr = new int[map.size()]; int index = 0; for (Map.Entry<Integer, Integer> entry : map.entrySet()) { newArr[index++] = entry.getKey(); }
以上就是java怎么去除数组中相同的数的详细内容,更多请关注其它相关文章!