判断一个数组是另一数组的子集
2016-03-02 01:28
239 查看
问:
如何判定数组b是否属于数组a
答:
注意:
尽量使用java collections的高级API,而避免使用迭代器,原因如下:
1.使用迭代的话每次添加或移除元素后重新调整集合将非常低效。
2.多线程情况下,每次在获取锁、执行操作和释放锁的过程中,都存在潜在的并发困境。
3.当添加或移除元素时,存取集合的其他线程会引起竞争条件。
但是需求有些歧义,子集的定义时否包括重复数据。
比如: a={“01”,”02”,”03”,”04”},b={“01”,”02”,”03”,”03”}
这种情况下,可能出现歧义,如果重复数据不合并来作为子集,那么a不包含b,需要另作处理。
String[] a={“01”,“03”,“05”} String[] b={“01”}
如何判定数组b是否属于数组a
答:
String[] a = { "01", "03", "05", "06" }; String[] b = { "01", "03", "05", "05" }; //生成不变List List listA = Arrays.asList(a); List listB = Arrays.asList(b); System.out.println(listA.containsAll(listB));
注意:
尽量使用java collections的高级API,而避免使用迭代器,原因如下:
1.使用迭代的话每次添加或移除元素后重新调整集合将非常低效。
2.多线程情况下,每次在获取锁、执行操作和释放锁的过程中,都存在潜在的并发困境。
3.当添加或移除元素时,存取集合的其他线程会引起竞争条件。
但是需求有些歧义,子集的定义时否包括重复数据。
比如: a={“01”,”02”,”03”,”04”},b={“01”,”02”,”03”,”03”}
这种情况下,可能出现歧义,如果重复数据不合并来作为子集,那么a不包含b,需要另作处理。
相关文章推荐
- Educational Codeforces Round 9
- 关于swift中约束会有的一些冲突解决
- cf#ecr9-D - Longest Subsequence
- 学习Linux决心书
- 程序员必须知道的10大基础实用算法及其讲解
- 个人进阶之路——安卓蓝牙模块(3)
- cf#ECR 9-C - The Smallest String Concatenation-水题
- JAVA二学(二)剖析String
- 143 php 接口
- PHP团队编码质量提升之道
- cf#ECR 9-B. Alice, Bob, Two Teams-DP
- c语言数据类型 之 内存对齐与位段
- 程序员必须知道的10大基础实用算法及其讲解
- iOS:手把手教你发布代码到CocoaPods(Trunk方式)
- maven 相关命令记录
- Delphi通过查找字符定位TADOQuery数据的位置
- HDU 4549 M斐波那契数列(矩阵快速幂&费马小定理)
- 5.7 Python API(for Elasticsearch)
- VMware 安装 Ubuntu 12 遇到坑 VMware是什么 不是虚拟机
- JavaScript中创建字典对象(dictionary)实例