从数组中删除重复项

今天,对曾经的体型进行了琢磨,发现一些新的用法与解法,比如对Java中的一些包,入import   java.util.Set ; import  java.util.HashSet; import  java.util.Iterator; import  java.util.List;  import  java.util.ArrayList;  import  java.util.Arrays;  

import  java.util.map;  import  java.util.HashMap等。偶尔发现这些数据结构,对数组的调用,栈,Hash队列,哈希图,数组 等的使用,和数组中索引与索引位置中的数字的关系,处理的很紧密。

举个例子:从排序数组中删除重复项,在不产生新的数组的条件下。遍历数组,比较前一个与后一个是否数值相同,找到不同的  那个往前放置,知道放完为止,即使该数组所应有的长度。代码如下:

package com.imooc;
public class Solution {
  public int removeDuplicates(int[] nums) {
  int j=1;
  for(int i=1;i<nums.length;i++)
  {
if(nums[i]!=nums[i-1])
{
nums[j]=nums[i];
j++;
}
  }
        return j;
    }
  public static void main(String[]args){
  int []arr=new int[]{1,2,2,3,3,3,100,100};
  Solution solve = new Solution();
  int length = solve.removeDuplicates(arr);
  for(int i=0;i<length;i++)
  {
  System.out.print(arr[i]+" ");
  }
  }

而对于从非排序数组中删除重复项,则用到了HashSet与Set。遍历数组,用set.contains()与set.add()去增加 if 的设置条件,然后将set中的数值读出到原来的数组中,用到 Iterator 去读出 set 队列中的数值,并用Arrays.sort()进行排序,就排序set队列长度下的数值。

package com.imooc;
import java.util.Set;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Arrays;
public class Solution{
public int removeDuplicates(int[] nums) {
Set<Integer> set = new HashSet<Integer>();
int len = 0;
for(int i=0;i<nums.length;i++){
if(set.contains(nums[i])!=true){
set.add(nums[i]);
len++;
}else{
continue;
}
}
Iterator<Integer> it = set.iterator();
int j=0;
while(it.hasNext())
{
nums[j]=it.next();

j++;
}
Arrays.sort(nums,0,j);
for(int i=0;i<j;i++){
System.out.println(nums[i]);
}


return j;
}
public static void main(String[]args){
int []nums = new int[]{2,1,1,2,3,4,5,4,6};
Solution solve = new Solution();
int length = solve.removeDuplicates(nums);

}
}

### 回答1: 在 Java 中,可以使用以下步骤来从数组删除重复项: 1. 定义一个 HashSet 对象,该对象不允许重复元素。 2. 遍历数组中的每个元素,并将其添加到 HashSet 中。如果元素已存在于 HashSet 中,则该元素是重复的,可以被忽略。 3. 使用 HashSet 的 toArray() 方法将其转换回数组。这将创建一个新的数组,其中不包含重复的元素。 下面是一个使用上述步骤的示例代码: ``` int[] array = {1, 2, 3, 4, 2, 3, 4, 5}; Set<Integer> set = new HashSet<>(); for (int i : array) { set.add(i); } int[] result = new int[set.size()]; int i = 0; for (int n : set) { result[i++] = n; } ``` 在上面的代码中,result 数组将是一个不包含重复元素的新数组。 另外,也可以使用 Java 8 中的 Stream API 和 distinct() 方法来实现这个功能。例如: ``` int[] array = {1, 2, 3, 4, 2, 3, 4, 5}; int[] result = Arrays.stream(array).distinct().toArray(); ``` 这将返回一个新的 int 数组,其中包含原数组中的所有不重复元素。 希望这对你有帮助! ### 回答2: 在Java中删除一个数组中的重复项可以通过以下步骤实现: 1. 首先,创建一个新的空数组,用于存储没有重复项的元素。 2. 遍历原始数组中的每个元素。 3. 在遍历的过程中,使用一个布尔变量来判断当前元素是否已经在新数组中出现过。 4. 如果当前元素没有在新数组中出现过,则将其添加到新数组中。 5. 最后,返回新数组作为结果。 以下是一个示例代码: ```java public static int[] removeDuplicates(int[] array) { int[] newArray = new int[array.length]; int index = 0; for (int i = 0; i < array.length; i++) { boolean isDuplicate = false; for (int j = 0; j < index; j++) { if (array[i] == newArray[j]) { isDuplicate = true; break; } } if (!isDuplicate) { newArray[index] = array[i]; index++; } } int[] result = new int[index]; System.arraycopy(newArray, 0, result, 0, index); return result; } ``` 这个方法的时间复杂度为O(n^2),可以通过遍历原始数组中的每个元素,并在新数组中进行查找来确定是否为重复项。值得注意的是,这个方法会保留数组中首次出现的重复项,而将其他重复项删除。如果想要保留最后出现的重复项,可以逆序遍历原始数组,并逆序添加到新数组中。 ### 回答3: Java从数组删除重复项的方法有很多种,以下是一种较为简单的实现方法: 1. 创建一个新的空数组,用于存储不重复的元素。 2. 使用for循环遍历原数组中的每个元素。 3. 在每次循环中,判断当前元素是否已经在新数组中存在。可以通过使用嵌套的for循环来遍历新数组,判断新数组中是否存在相同的元素。 4. 如果当前元素在新数组中不存在,则将其添加到新数组中。 5. 循环结束后,新数组中就存储了原数组中的不重复元素。 下面是一个示例代码: ``` public static int[] removeDuplicates(int[] arr) { int[] newArr = new int[arr.length]; int index = 0; // 新数组的索引 for (int i = 0; i < arr.length; i++) { boolean isDuplicate = false; for (int j = 0; j < index; j++) { if (arr[i] == newArr[j]) { isDuplicate = true; break; } } if (!isDuplicate) { newArr[index++] = arr[i]; } } int[] result = new int[index]; for (int i = 0; i < index; i++) { result[i] = newArr[i]; } return result; } ``` 使用该方法调用示例: ``` int[] arr = {1, 2, 3, 1, 2, 4, 5, 3}; int[] newArr = removeDuplicates(arr); System.out.println(Arrays.toString(newArr)); // [1, 2, 3, 4, 5] ``` 这样就能够从数组删除重复项并返回一个不含重复元素的新数组
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

luolvzhou

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值