- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我得到了一个O(n)
时间复杂度的问题:
“给定一个数字列表和数字 x。查找列表中是否有 2 个数字加起来为 x?”
这是我的解决方案:
public class SumMatchResult {
public static void main(String[] args){
int[] numberList = {6,1,8,7,4,6};
int requiredSum = 8;
boolean isSumPresent = checkSumPresentHash(numberList,requiredSum);
if(isSumPresent) {
System.out.println("Numbers exist");
}else {
System.out.println("Numbers donot exist");
}
}
private static boolean checkSumPresentHash(int[] numberList, int requiredSum) {
Map<Integer, Integer> m = new HashMap<Integer,Integer>();
int count = 0;
for(int i=0;i<numberList.length;i++){
m.put(i, numberList[i]);
}
for(int i=0;i<numberList.length;i++){
if(m.containsValue(requiredSum - numberList[i])){
count++;
}
}
if(count>1){
return true;
}
return false;
}
}
我正在使用 HashMap.containsValue()
而不是使用 HashSet.contains()
肯定具有 O(1)
的复杂性> 因为,我必须考虑我的输入可能包含相同值的情况。例如,在上述情况下,我可以有一组输入值 {3,6,4,4,7}
与 sum 8
匹配,这应该返回 true
。
我上面的解决方案的时间复杂度取决于 HashMap.containsValue()
方法的复杂度。请阐明 containsValue()
方法的时间复杂度,并建议我在时间复杂度方面是否有上述问题的更好解决方案。谢谢。
最佳答案
要回答标题中的问题-正如其他人所说,containsValue
是O(n),因为没有 key 它不知道它在哪里并且算法必须遍历所有 map 中存储的值。
要回答问题正文中的问题 - 关于如何解决问题 - 只需考虑您是否真的需要一张通用 map ,该 map 可以计算您看到每个数字的实例数。我的意思是,唯一你会关心一个数字是否不止一次出现的时候是它的 x/2,对吧?这对我来说就像一个角落里的箱子。只需添加一个检查该极端情况的测试 - 比如在你的集合构造循环中嵌入 if (numberList[i] == requiredSum/2) half++
,然后 if (requiredSum % 2 == 0 && half == 2) 在它之后返回 true
(参见下面的其他变体)。
然后你可以只遍历集合并为每个项目检查 requiredSum-item
是否也出现在集合中。
总结(尽可能提前退出):
Set<Integer> seen = new HashSet<Integer>();
boolean halfSeen = false;
for (int num : numberList) {
if (num == requiredSum/2 && requiredSum % 2 == 0) {
if (halfSeen) return true;
halfSeen = true;
} else {
seen.add(num);
}
}
for (int num : seen) {
if (seen.contains(requiredSum - num)) return true;
}
return false;
关于java - java中HashMap.containsValue()的时间复杂度是多少?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16757359/
我正在尝试使用 HashMap 和数组为 6 支球队创建一个赛程列表。我有 6 个团队。每支球队必须互相比赛两次。我将从原始团队列表中随机删除每个团队并将其添加到新列表中。这个新列表被添加到 Hash
我有一个巨大的 float 组,我必须从中删除重复项。我尝试创建一个哈希表来填充唯一值并将其传递回另一个数组并返回它。问题出在 containsValue 方法中,该方法总是返回 false,因此所有
这个问题已经有答案了: How do I compare strings in Java? (23 个回答) 已关闭 4 年前。 我正在尝试使用字典单词的哈希表编写拼写检查器。我目前正在尝试将文本文档
我有一个 HashSet,其中包含通过读取二进制文件生成的自定义对象。我还有一个通过读取 DBF 文件的每一行生成的字典。两者都有一个索引属性,它们相互对齐。例如,我的词典中的第 10 项将与我的 H
我正在开发一个程序来验证 map 是否包含某些值集。 Map API 有一种称为 map.containsValue(string) 的方法。但是,此方法将完整的字符串验证为值。 import jav
我有一个 HashMap,我需要通过它的整数值来获取一个项目。我注意到有一个 containsValue() 函数,但看起来我仍然必须遍历 map 才能找到正确的索引。 我的问题是;如果之后需要遍历它
我有一个字典,我在其中将一个键和 2 个值存储在一个元组中,如下所示: variableDictionary = new Dictionary>(); 所以我的字典是:key, 我想检查 value
我得到了一个O(n)时间复杂度的问题: “给定一个数字列表和数字 x。查找列表中是否有 2 个数字加起来为 x?” 这是我的解决方案: public class SumMatchResult {
因此,我试图在 powershell 中创建一个函数,该函数将用户所属的所有组嵌套在广告中。我将这些组映射到一个哈希表中,使用 AD 中的通用名称作为值。 这很顺利,该函数返回一个包含我所有组的哈希表
为什么会发生这种情况以及如何避免?我认为它只检查引用,但这不是很方便。 import java.util.LinkedHashMap; public class CheckingLinkedHashM
java中的containsValue是如何工作的?它是否将给定对象与 map 中已有的值进行比较?如果是这样,为什么这不起作用? 我有以下类:class Node{ 整数n; 整数重量; 字符串 v
如果我在类型和值中输入了错误的值,我希望我的程序显示错误消息。 错误消息适用于类型,但不适用于值。这是怎么回事? Map Heart = new HashMap(); Heart.put("A", "
我正在尝试将我用 Java 编写的算法转换为 Scala,但我在使用 Java 中的 containsValue() 方法时遇到了问题。我想做一些类似于 if (hashMap.containsVal
我有一本映射到摩尔斯电码的所有字母表 Dictionary data = new Dictionary(); data.Add("a", ".-"); data.Add
我有一张 map 如下: final Map> existingNames = this.getExistingCIs(_actual,_names.keySet()); 它返回: {myobj43c
containsValue() 在 AbstractMap 类中实现如下: public boolean containsValue(Object value) { Iterator> i =
我有一个下面的程序,其中有一个 HashMap 。 HashMap 的键是简单的整数,值是整数数组。程序如下: Map myMap = new HashMap(); myMap.put("EvenN
我正在实现一个 HashMap,即使字符重复,它也总是返回 false。我尝试了其他堆栈溢出问题中给出的解决方案,但没有帮助,带有函数 contains() 的哈希表也是如此。 HashMap ht
我想打印从扫描仪对象到达这里的选定键和值。我尝试过这种方式,发现有区别: TreeMap oldbooks = new TreeMap(); oldbooks.put("WaltDis
是否有有效的方法来检查字典中的值,一旦知道该值存在,然后找到该值的键? //检查字典已经有sortedWord(即key是word,value是sortedWord) if (anagramDict
我是一名优秀的程序员,十分优秀!