java求“交、叉、并集”

01	package test;
02	 
03	import java.util.HashSet;
04	import java.util.Set;
05	 
06	public class Test {
07	     
08	    public static void main(String[] args) {
09	        Set<Integer> result = new HashSet<Integer>();
10	        Set<Integer> set1 = new HashSet<Integer>(){{
11	            add(1);
12	            add(3);
13	            add(5);
14	        }};
15	         
16	        Set<Integer> set2 = new HashSet<Integer>(){{
17	            add(1);
18	            add(2);
19	            add(3);
20	        }};
21	         
22	        result.clear();
23	        result.addAll(set1);
24	        result.retainAll(set2);
25	        System.out.println("交集:"+result);
26	         
27	        result.clear();
28	        result.addAll(set1);
29	        result.removeAll(set2);
30	        System.out.println("差集:"+result);
31	         
32	        result.clear();
33	        result.addAll(set1);
34	        result.addAll(set2);
35	        System.out.println("并集:"+result);
36	         
37	    }
38	 
39	}


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
假设我们有两个表 TableA 和 TableB,每个表都包含一个名为 "id" 的整数列。我们的目标是获取 TableA 和 TableB 的并集,并将结果写入文本文件。 以下是使用 Java 实现该功能的示例代码: ```java import java.io.BufferedWriter; import java.io.FileWriter; import java.io.IOException; import java.util.HashSet; import java.util.Set; public class TableIntersectionUnion { public static void main(String[] args) { // 创建 TableA 和 TableB int[] tableA = { 1, 2, 3, 4, 5 }; int[] tableB = { 3, 4, 5, 6, 7 }; // 计算并集 Set<Integer> intersection = new HashSet<>(); Set<Integer> union = new HashSet<>(); for (int i = 0; i < tableA.length; i++) { if (contains(tableB, tableA[i])) { intersection.add(tableA[i]); } union.add(tableA[i]); } for (int i = 0; i < tableB.length; i++) { if (!contains(tableA, tableB[i])) { union.add(tableB[i]); } } // 将结果写入文本文件 String resultPath = "result.txt"; writeToFile(resultPath, "Intersection: " + intersection.toString() + "\n"); writeToFile(resultPath, "Union: " + union.toString()); } private static boolean contains(int[] arr, int val) { for (int i = 0; i < arr.length; i++) { if (arr[i] == val) { return true; } } return false; } private static void writeToFile(String path, String content) { try (BufferedWriter writer = new BufferedWriter(new FileWriter(path, true))) { writer.append(content); } catch (IOException e) { e.printStackTrace(); } } } ``` 在上面的代码中,我们首先创建了 TableA 和 TableB,并使用 HashSet 实现了并集的计算。然后,我们使用 BufferedWriter 将结果写入名为 "result.txt" 的文本文件中。注意,我们使用了 try-with-resources 语句来确保 BufferedWriter 能够正确关闭。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值