- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
对于一项作业,我必须编写一个程序来处理哈希表。我已经做到了,它似乎工作得很好,只是如果我在特定点输入一个变量,它不会产生预期的输出,如果我改变它,它会起作用(让我相信它与读取数字的顺序)。
它会在开始时读取与用户输入一样多的数字,然后对它们进行哈希处理并将它们添加到哈希表中。然后计算出该数字出现的次数,如果它大于用户输入的阈值(假设用户输入 4 作为阈值,333 出现 5 次)它将打印出该数字。
在我的程序中,它应该打印出 333,根据我的计数,它出现了 8 次,我将阈值设置为 4。但事实并非如此。如果我改变输出,让它出现在输入的前半部分,它就可以工作。这让我觉得它只是读取数组中 LEN/2 之前的数字(LEN 是我们被赋予设置为宏的值)。
代码如下:
#include <stdio.h>
#define LEN 31
int main(int argc, char *argv[]) {
int keys[LEN];
int values[LEN];
int numAmount, threshold, i, j, num, index, counter, count, n, advance = 1;
// Set all indices of the arrays keys and values to 0
for (i = 0; i < LEN; i++) {
keys[i] = 0;
values[i] = 0;
}
scanf("%d %d", &numAmount, &threshold);
if (numAmount <= 0 || threshold <= 0) {
printf("\nLength of array and/or threshold is not a positive integer.");
advance = 0;
}
// Main loop for adding numbers to the hash table
for (i = 0; i < numAmount && advance == 1; i++) {
counter = 0;
for (j = 0; j < LEN; j++) {
if (keys[j] != 0) {
counter++;
}
}
if (counter > LEN / 2) { // Load factor is greater than 1/2
printf("Load factor causes program to exit.");
break;
}
scanf("%d", &num);
// Illegal character detection
// if (!num > 0) {
// printf("Illegal character entry. Must be an integer from 0-9.");
// break;
// }
index = num % LEN;
if (keys[index] == 0) { // empty
keys[index] = num;
values[index] = 1;
}
else if (keys[index] == num) {
values[index]++;
}
else if (keys[index] != 0 && keys[index] != num) { // Collision
count = 0, n = 1;
while (keys[index] != 0 || keys[index] != num) { // Collision solver
if (count > LEN) {
break;
}
index = (index + n) % LEN;
n++;
count++;
}
}
}
// Only prints the results out if program went through with creating the hash table
if (advance == 1) {
for (i = 0; i < LEN; i++) {
if (values[i] >= threshold) {
printf("%d ", keys[i]);
values[i] = 0;
}
}
}
printf("\n");
}
如果我将其复制并粘贴为输入:
40 4
105 50 3 55 100
532 550 100 55 100
550 55 100 240 42
100 99 105 333 120
333 333 100 315 333
120 333 240 550 333
302 100 333 240 333
42 55 42 55 3
它返回100 55
,这只是期望输出的2/3;它缺少 333。
但是如果我把333放在输入的开头附近,比如:
40 4
105 333 3 55 100
53 550 100 55 100
550 55 100 240 42
100 99 105 333 120
333 333 100 315 333
120 333 240 550 50
302 100 333 240 333
42 55 42 55 3
它按预期工作,并输出 100 333 55
。
我已经仔细研究了一段时间的代码,但我似乎无法弄清楚为什么数字的这种放置对于程序的正常运行如此重要。
另外,快速的第二个问题,我们被要求做的一件事是确保没有非法字符输入,基本上是任何非数字的字符。我如何检测到这个?我知道我可以使用 if 语句(我在上面的代码中注释掉了一个 if 语句的结构),但我不确定 if 语句的条件应该是什么。我知道正则表达式,但是使用 C 的正则表达式让我非常困惑。
最佳答案
我发现您的代码有几个问题。排名不分先后:
你永远不会对 index
做任何事情和 num
以及在碰撞求解器循环之后发生的诸如此类的事情,因此碰撞值会被简单地丢弃。
在 keys[index] != 0 || keys[index] != num
时让碰撞求解器循环将导致它拒绝任何已经对应于 num
的索引,因为这样的索引在 keys
中已经有一个非零值;更改 ||
到 &&
.
正在做 index = (index + n) % LEN
原因index
继续累积偏移量,这(对于 LEN
= 31,至少)导致一些索引被检查不止一次而其他索引根本不被检查。做index = (index + 1) % LEN
相反并免除 n
完全。
至于检测无效输入,简单的检测是否scanf
返回 0(表示输入的下一部分未能匹配 "%d"
)或不返回。
关于c - 为什么我的程序显然没有读取所有输入数字,我如何检测非数字输入?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9724508/
我遇到以下问题。我想读取一个包含数百万行和数百列的大型 csv。我想向下转换列的数据类型。我的方法是读取 csv,然后使用 pd.to_numeric() 对其进行向下转换。我不知道列数及其类型。在读
目前,我从 SQL server (2008) 数据库获取数据。 cyurrent的方法是使用DataTable,然后将其传递并使用。 if (parameters != null)
我有以下问题。我有一个巨大的 csv 文件,想用多处理加载它。对于一个包含 500000 行和 130 列不同数据类型的示例文件,Pandas 需要 19 秒。我试过 dask 因为我想多处理阅读。但
是否有关于用于序列化各种 MFC 数据结构的二进制格式的明确文档?我已经能够在十六进制编辑器中查看我自己的一些类,并使用 Java 的 ByteBuffer 类读取它们(使用自动字节顺序转换等)。 但
我正在使用 Selenium 进行测试,我们用 HTML 文件编写测试用例,并用它们制作测试套件,我们的要求是编写足够健壮的测试用例,以根据测试环境改变自身。 为此,我不希望在 HTML 脚本本身中包
我需要一个 JavaScript 代码来读取存储为 .txt 文件的字典(或者也可以保存为任何其他类型的文件。它也可以在线获得)并将其内容存储在一个变量中。我不能找到一种让 JavaScript 像
我正在尝试遍历包含 SSH 登录和其他日志的日志文本文件。 程序正在返回 SSH 登录的总数。 我的解决方案确实有效,但似乎有点慢(在 200mo 文件上大约需要 3.5 秒)。我想知道是否有任何方法
我正在将大量数据从一个电子表格复制到工作簿中的其他 160 个电子表格。目前,Excel (2013) 遇到错误,因为它没有足够的资源来完成操作。 我的目标是将工作表 4 中 V13:XI1150 范
我正在尝试读取一个有 1147 行的文本文件。下面的代码仅读取第 1050-1147 行。我的目标是读取整个文件并提取位于不同行的特定值以在脚本中使用。一个示例是包含“BlockList: 2”的行中
我正在为游戏编写解释器。用户将其移动输入解释器,程序执行该移动。 现在我想为每个决定实现一个时间限制。玩家不应该能够思考超过 30 秒来写一个移动并按下回车。 call_with_time_limit
以this file例如,我正在尝试读取 data.frame 中的数据。来自 the doc (pdf 文件,表 1),它遵循一些 fortran 约定。我尝试了以下但收效甚微: dir 0' 将
我正在使用 R 阅读 Outlook 附件。我的引用在这里:Download attachment from an outlook email using R 这是我的电子邮件的截图: 这每天都会发送
我不会从表格中读取行来将主题放在列表中 php脚本 $url_obj='http://'.$host.':8069/xmlrpc/object'; $sock=new xmlrpc_client($u
我有一个这样的 csv 文件: id,name,value 1,peter,5 2,peter\,paul,3 我如何读取此文件并告诉 R "\," 不表示新列,仅表示 ","。 我必须添加该文件
我正在尝试读取 ~/Library/Preferences/com.apple.mail.plist (在 Snow Leopard 上)以获取电子邮件地址和其他信息以进入“关于”对话框。我使用以下代
This question already has answers here: How do I use floating-point division in bash? (19个回答) 5个月前关闭
本练习的目标是读取输入文件并将其存储到表中,然后验证输入中的某些字段并输出任何错误记录。我需要读取并存储每个策略组,以便表中一次仅存储 5 条记录,而不是整个文件。 所以我需要读取一个包含 5 条记录
据我了解,LWT 插入始终以 SERIAL 一致性级别完成。如果为 true,这是否意味着读取作为 LWT 插入的行可以安全地以 ANY 的一致性级别读取? 换句话说,我假设 LWT 插入是完全一致的
我看到很多很多通过java脚本读取cookie的函数,但我只想在变量中使用它一次,我是JS新手。 这是我的代码 var TheNumber = (Math.random() + '') * 10000
我正在使用 asp.net 和 C#。我在服务器上部署了一个应用程序[已发布],现在我想查看该网站的代码,据我所知,我可以阅读程序集来查看代码。 请告诉我如何实现它。 提前致谢。 最佳答案 您可以使用
我是一名优秀的程序员,十分优秀!