- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在制作一个具有线性探测碰撞的哈希表。我正在尝试将哈希表的元素添加到集合或集合中。我设置哈希表的方式是,它是一个节点数组,其中包含通用类型 K 的“键”和通用类型 V 的“值”。表中没有数组节点的索引是null,但原来有节点但被删除的索引标记为包含 new Node(-1, -1) 的 Node。当我去打印哈希表时,我想避免打印已删除的点(包含键 -1 的索引)。相关代码如下:
添加到集合或集合的方法(在哈希表类中)
@Override
public Set<K> keySet() {
Set<K> s = new HashSet<K>();
for(int i=0; i<this.hashtable.length; i++) {
if(this.hashtable[i] != null && this.hashtable[i].key != -1)
s.add(this.hashtable[i].key);
}
return s;
}
@Override
public Collection<V> values() {
LinkedList<V> l = new LinkedList<V>();
for(int i=0; i<this.hashtable.length; i++) {
if(this.hashtable[i] != null && this.hashtable[i].key != -1)
l.add(this.hashtable[i].val);
}
return l;
}
节点类(不是哈希表类):
private final class Node<K extends Comparable<? super K>, V> {
public K key;
public V val;
public Node() {
this.key = null;
this.val = null;
}
public Node(K theKey, V theValue) {
this.key = theKey;
this.val = theValue;
}
}
实际哈希表类中的主要方法:
public static void main(String[] args) {
MyJHUHashMap<Integer, String> m = new MyJHUHashMap<>();
m.put(1, "1!");
m.put(2, "2!");
m.put(3, "3!");
m.put(4, "4!");
m.put(5, "5!");
m.put(6, "6!");
m.put(7, "7!");
m.put(8, "8!");
m.put(9, "9!");
m.put(10, "10!");
m.put(11, "11!");
m.put(12, "12!");
m.put(13, "6!");
m.put(14, "7!");
m.put(15, "8!");
m.put(16, "9!");
m.put(17, "10!");
m.put(18, "11!");
m.put(19, "12!");
m.put(20, "10!");
m.put(21, "11!");
m.put(22, "12!");
m.put(23, "23!");
System.out.println(m.get(4));
System.out.println(m.get(12));
System.out.println(m.get(25));
System.out.println(m.containsKey(22));
System.out.println(m.containsKey(35));
m.remove(23);
m.remove(18);
//m.put(7, 7);
System.out.println(m.hashtable.length);
System.out.println(m.size());
for(int i=0; i<m.hashtable.length; i++) {
if(m.hashtable[i] != null && m.hashtable[i].key != -1)
System.out.print(m.hashtable[i].key + " ");
}
}
长度似乎正确,大小似乎正确,并且按键确实打印出来,但是包含 -1 值。为了克服这个问题,我在方法中编写了“this.hashtable[i].key!= -1”。但是,我在 keySet() 和 value() 方法中收到错误“不兼容的操作数类型 K 和 int”,但在 main 方法中却没有收到错误消息。谁能指出如何克服这个问题?
最佳答案
不要使用 -1 作为“特殊键值”,因为您的键必须是 K 类型(并且 K 可以是任何内容:字符串、日期等)。
使用 null 代替。
关于java - K 和 int Java 之间不兼容的操作数类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26702738/
int enter_path(char** path) { char* standard = "./questions.txt"; printf("\n\t%s\n\t%s",
我有以下几行代码: #define PORT 9987 和 char *ptr = (char *)&PORT; 这似乎适用于我的服务器代码。但是当我在我的客户端代码中写它时,它给出了这个错误信息:
大家好,我在成员函数中有以下内容 int tt = 6; vector>& temp = m_egressCandidatesByDestAndOtMode[tt]; set& egressCandi
我知道您可以通过以下方式在正则表达式中使用 NOT 操作数: [^AB] :匹配除 "A" 之外的任何内容或"B" A(?!B) :匹配"A" ,后面不跟 "B" (?
我的代码如下,下面还解释了为什么会发生左值; typedef struct test_item { char id[MENU_NAME_LEN + NULL_SPACE]; MenuF
我正在审查一些 javascript 代码,程序员在几个地方使用了 >>。我试图在谷歌上搜索但找不到这个操作数/运算符的作用。所以我来了。下面的代码示例: var triplet=(((binarra
我使用以下行(希望这是最佳实践,如果不正确请纠正我)来处理命令行选项: #!/usr/bin/bash read -r -d '' HELP &2 for i in "${invalid_opti
我正在尝试编辑一个计时器应用程序,出现了这行代码。我该如何解决? let styleMask: Int = NSClosableWindowMask | NSTitledWindowMask 错误是:
我可以得到两个特定日期之间的差异,这将等于日期总数。现在我想将工作日除以总天数并得到整数输出。 @IBAction func go(_ sender: UIButton) { let con
我的项目有一个问题,它应该使用一个线程将每一行相加,然后将它们全部相加,但是我收到一个错误,指出左值需要作为一元 '&"操作数 pthread_create(&tid, NULL, &sum_line
我的代码有问题。有以下功能: static Poly PolyFromCoeff(int coeff); static Mono MonoFromPoly(const Poly *p, int exp
在 C# 中是否没有字符串的 OR 操作数? 我正在查看 Microsoft C# 操作数页面 - 没有关于字符串的任何类型的 OR。 我有一个要写的 if 语句: if (Convert.ToStr
下面的函数左移一个double操作数: double shl(double x,unsigned long long n) { unsigned long long* p = (unsigne
我在 Linux 中使用了以下简单的 ksh 脚本 #!/bin/ksh set -x ### Process list of *.dat files if [ -f *.dat ] then pri
我有一个使用 Entity Framework 的查询。它有许多不同的操作数,我对其优先级感到困惑。我得到了错误的结果。我需要所有 IsPaid == true 或 IsPaid == null 的记
我有以下代码来尝试创建一个约束数组以添加到 View 中: let views = ["button": button] let metrics = ["margin": 16] var constr
这个问题在这里已经有了答案: How to compare one value against multiple values - Swift (8 个答案) 关闭 6 年前。 我有一种情况,我必须
我使用 jquery $.ajax 将请求发送到服务器,它返回 JSON。 $.ajax({ url: 'moreMonth.ajax', data: { startIndex: id },
我的问题是程序没有按照“他”的预期读取代码。 我有 if (hero.getPos() == (6 | 11 | 16)) { move = new Object[] {"Up", "Righ
我在对象中创建线程时遇到问题。错误是需要作为一元“&”操作数的左值 CPP文件 #include "AirQ.h" static int i=0; AirQ::AirQ(int pinNo, bool
我是一名优秀的程序员,十分优秀!