草庐IT

# java合并两个list 并去重,指定保留其中一个list的重复数据

茶颜悦色的马铃薯 2023-06-17 原文

在Java中,有多种方法可以合并两个List并去重,指定保留其中一个List的重复数据。下面介绍几种常见的方法,并附上代码示例。

方法一:使用addAll()方法和contains()方法

该方法首先将一个List的所有元素加入到目标List中,然后遍历另一个List,如果目标List中不包含该元素,则将该元素加入到目标List中。最后得到的就是合并后的List,并去重,但不保留重复数据。

示例代码:

List<String> list1 = Arrays.asList("A", "B", "C", "D", "E");
List<String> list2 = Arrays.asList("C", "D", "E", "F", "G");

List<String> mergedList = new ArrayList<>();
mergedList.addAll(list1);  // 将list1的元素加入到mergedList中

for (String str : list2) {
    if (!mergedList.contains(str)) {
        mergedList.add(str);  // 如果mergedList中不包含该元素,则将该元素加入到mergedList中
    }
}

List<String> duplicateList = new ArrayList<>();
duplicateList.addAll(list1);  // 将list1的元素加入到duplicateList中

for (String str : list2) {
    if (list1.contains(str) && !duplicateList.contains(str)) {
        duplicateList.add(str);  // 如果list1和list2中都包含该元素且duplicateList中不包含该元素,则将该元素加入到duplicateList中
    }
}

System.out.println("Merged List: " + mergedList);  // 输出合并后的List
System.out.println("Duplicate List: " + duplicateList);  // 输出保留重复数据后的List

上述代码将两个List合并后去重,同时保留了list1中的重复数据。具体实现过程如下:

  1. 首先将list1中的所有元素加入到mergedList中。
  2. 遍历list2中的每个元素,如果mergedList中不包含该元素,则将该元素加入到mergedList中。
  3. 将list1中的所有元素加入到duplicateList中。
  4. 遍历list2中的每个元素,如果list1和list2中都包含该元素且duplicateList中不包含该元素,则将该元素加入到duplicateList中。
  5. 最后输出合并后的List和保留重复数据后的List。

输出结果如下:

Merged List: [A, B, C, D, E, F, G]
Duplicate List: [A, B, C, D, E]

方法二:使用SET去重

首先将两个List合并成一个List,然后利用Set去重,最后再将结果转换为List。在这个过程中,我们可以使用一个Map来记录需要保留的List中的重复元素。

示例代码如下:

List<Integer> list1 = Arrays.asList(1, 2, 3, 3, 4);
List<Integer> list2 = Arrays.asList(2, 3, 5);

// 将两个List合并
List<Integer> list = new ArrayList<>(list1);
list.addAll(list2);

// 使用Set去重
Set<Integer> set = new HashSet<>(list);

// 用Map记录需要保留的List中的重复元素
Map<Integer, Integer> map = new HashMap<>();
for (Integer num : list1) {
    if (set.contains(num)) {
        if (!map.containsKey(num)) {
            map.put(num, 1);
        } else {
            map.put(num, map.get(num) + 1);
        }
        set.remove(num);
    }
}

// 将结果转换为List
List<Integer> result = new ArrayList<>(set);
for (Integer num : map.keySet()) {
    for (int i = 0; i < map.get(num); i++) {
        result.add(num);
    }
}

System.out.println("Merged List: " + list);  // 输出合并后的List
System.out.println("Duplicate List: " + result);  // 输出保留重复数据后的List


输出结果如下:

Merged List: [1, 2, 3, 3, 4, 2, 3, 5]
Duplicate List: [5, 1, 2, 3, 4]

方法三:使用Stream去重

当我们需要合并两个List并去重时,可以使用Java 8的Stream API来实现。在这个过程中,我们可以使用distinct()方法来去重,使用collect(Collectors.toList())方法来将结果收集到List中。在指定保留其中一个list的重复数据时,我们可以使用retainAll()方法来实现。

以下是示例代码:

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;

public class MergeAndDistinctListExample {

    public static void main(String[] args) {

        // 创建两个List
        List<Integer> list1 = new ArrayList<>(Arrays.asList(1, 2, 3, 4, 5));
        List<Integer> list2 = new ArrayList<>(Arrays.asList(3, 4, 5, 6, 7));

        // 合并两个List并去重
        List<Integer> result = Stream.concat(list1.stream(), list2.stream())
                .distinct()
                .collect(Collectors.toList());

        System.out.println("合并并去重后的List:" + result);

        // 保留其中一个List的重复数据
        list1.retainAll(list2);

        System.out.println("保留list2中的重复数据后的list1:" + list1);
    }
}

运行以上代码会输出以下结果:

合并并去重后的List:[1, 2, 3, 4, 5, 6, 7]
保留list2中的重复数据后的list1:[3, 4, 5]

在上面的示例代码中,我们首先创建了两个List,然后使用Stream.concat()方法将两个List合并,然后使用distinct()方法去重,并使用collect(Collectors.toList())方法将结果收集到List中。

接着,我们使用retainAll()方法保留其中一个List的重复数据。这个方法将修改调用它的List,使其只包含与指定集合相交的元素,也就是只保留重复的元素。在这个例子中,我们将会保留list2中的重复数据,并修改list1来只包含与list2相交的元素。

请注意,在这个示例代码中,我们只保留了list1中与list2相交的元素。如果需要保留list2中的重复数据,只需要调用list2.retainAll(list1)即可。

方法四:利用Java 8的Map.merge()方法

Java 8中的Map类提供了一个merge()方法,可以方便地对Map中的键值对进行合并操作。我们可以先将需要保留的List中的元素转换成一个Map,然后遍历另一个List进行合并操作。

示例代码如下:

使用 Java 8 的 Stream API,结合 Collectors.toMap() 和 merge() 方法来实现。具体实现步骤如下:

  1. 将两个 list 合并为一个 list;
  2. 将合并后的 list 转为 Stream;
  3. 使用 Collectors.toMap() 方法将 Stream 中的元素转为 Map;
  4. 在 toMap() 方法中指定 key 和 value,对于重复的 key,使用 merge() 方法合并 value;
  5. 将 Map 中的 value 转为 list,作为最终的结果。

下面是代码示例:

import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;

public class MergeListExample {

    public static void main(String[] args) {
        List<String> list1 = new ArrayList<>();
        list1.add("A");
        list1.add("B");
        list1.add("C");
        list1.add("D");

        List<String> list2 = new ArrayList<>();
        list2.add("C");
        list2.add("D");
        list2.add("E");
        list2.add("F");

        List<String> mergedList = mergeLists(list1, list2);

        System.out.println("Merged list with duplicates: " + mergedList);

        List<String> distinctList = mergedList.stream().distinct().collect(Collectors.toList());

        System.out.println("Distinct merged list: " + distinctList);
    }

    private static List<String> mergeLists(List<String> list1, List<String> list2) {
        List<String> mergedList = new ArrayList<>(list1);
        mergedList.addAll(list2);
        Map<String, String> map = mergedList.stream()
                .collect(Collectors.toMap(s -> s, s -> s, (s1, s2) -> s1));
        return new ArrayList<>(map.values());
    }
}

该示例中,我们首先定义了两个 list,然后调用了 mergeLists() 方法来合并两个 list 并去重。在该方法中,我们先将两个 list 合并为一个 list,然后将其转为 Stream。接着使用 Collectors.toMap() 方法将 Stream 中的元素转为 Map,并在 toMap() 方法中指定 key 和 value,对于重复的 key,使用 merge() 方法合并 value。最后将 Map 中的 value 转为 list,作为最终的结果。

输出结果如下:

Merged list with duplicates: [A, B, C, D, C, D, E, F]
Distinct merged list: [A, B, C, D, E, F]

欢迎给位大佬前来纠正不足,小弟万分感谢

有关# java合并两个list 并去重,指定保留其中一个list的重复数据的更多相关文章

  1. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

    我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

  2. ruby - 如何指定 Rack 处理程序 - 2

    Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack

  3. ruby - 使用 Vim Rails,您可以创建一个新的迁移文件并一次性打开它吗? - 2

    使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta

  4. ruby-on-rails - Rails - 一个 View 中的多个模型 - 2

    我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何

  5. ruby-on-rails - 渲染另一个 Controller 的 View - 2

    我想要做的是有2个不同的Controller,client和test_client。客户端Controller已经构建,我想创建一个test_clientController,我可以使用它来玩弄客户端的UI并根据需要进行调整。我主要是想绕过我在客户端中内置的验证及其对加载数据的管理Controller的依赖。所以我希望test_clientController加载示例数据集,然后呈现客户端Controller的索引View,以便我可以调整客户端UI。就是这样。我在test_clients索引方法中试过这个:classTestClientdefindexrender:template=>

  6. ruby-on-rails - 如何在 ruby​​ 中使用两个参数异步运行 exe? - 2

    exe应该在我打开页面时运行。异步进程需要运行。有什么方法可以在ruby​​中使用两个参数异步运行exe吗?我已经尝试过ruby​​命令-system()、exec()但它正在等待过程完成。我需要用参数启动exe,无需等待进程完成是否有任何ruby​​gems会支持我的问题? 最佳答案 您可以使用Process.spawn和Process.wait2:pid=Process.spawn'your.exe','--option'#Later...pid,status=Process.wait2pid您的程序将作为解释器的子进程执行。除

  7. ruby-on-rails - 如果 Object::try 被发送到一个 nil 对象,为什么它会起作用? - 2

    如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象

  8. ruby - 为什么 SecureRandom.uuid 创建一个唯一的字符串? - 2

    关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion为什么SecureRandom.uuid创建一个唯一的字符串?SecureRandom.uuid#=>"35cb4e30-54e1-49f9-b5ce-4134799eb2c0"SecureRandom.uuid方法创建的字符串从不重复?

  9. java - 等价于 Java 中的 Ruby Hash - 2

    我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/

  10. ruby-on-rails - 在 ruby​​ .gemspec 文件中,如何指定依赖项的多个版本? - 2

    我正在尝试修改当前依赖于定义为activeresource的gem:s.add_dependency"activeresource","~>3.0"为了让gem与Rails4一起工作,我需要扩展依赖关系以与activeresource的版本3或4一起工作。我不想简单地添加以下内容,因为它可能会在以后引起问题:s.add_dependency"activeresource",">=3.0"有没有办法指定可接受版本的列表?~>3.0还是~>4.0? 最佳答案 根据thedocumentation,如果你想要3到4之间的所有版本,你可以这

随机推荐