- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在进行 K&R 练习 6-4,即:
6-4. Write a program that prints the distinct words in its input sorted into decreasing order of frequency of occurrence. Precede each word by its count.
我决定做的是创建一个名为 dstncFreqNode6_4 的结构:
struct dstncFreqNode6_4
{
char *word;
int count;
struct dstncFreqNode6_4 *left;
struct dstncFreqNode6_4 *right;
};
然后我解析输入的单词,并为每个不同的单词创建一个“dstncFreqNode6_4”节点和两个指向它的指针:一个插入 BST(添加新单词/更新已经遇到的单词的计数),和一个插入到“dsntFredNode6_4”指针的全局数组中。
这样做是为了让我可以通过遍历 BST(它包含指向目前遇到的所有单词的指针)来更新单词(节点)的计数。整个输入被解析后,指针数组将按成员的“计数”变量排序,然后打印。由于
添加新词/更新计数的代码在这里:(我不认为它有什么问题,因为 BST 和数组似乎被正确填充,所以你可以忽略它):
//"wordCounts" is originally a global dstncFreqNode6_4** declared outside the function, numWords is the current length of the array
struct dstncFreqNode6_4 *addFreqNode6_4(struct dstncFreqNode6_4 *root, char *word)
{
if(root == NULL)
{
root = (struct dstncFreqNode6_4 *) malloc(sizeof(struct dstncFreqNode6_4));
root -> word = word;
root -> count = 1;
root -> left = NULL;
root -> right = NULL;
struct dstncFreqNode6_4 **p;
wordCounts = (struct dstncFreqNode6_4 **) realloc(wordCounts, sizeof(struct dstncFreqNode6_4*) * (numWords +1));
p = wordCounts + numWords++;
(*p) = root;
}
else if(strcmp(word, root -> word) < 0)
root -> left = addFreqNode6_4(root -> left, word);
else if(strcmp(word, root -> word) > 0)
root -> right = addFreqNode6_4(root -> right, word);
else
root -> count++;
return root;
所以除了排序之外,我的一切都正常工作;它根本不会对数组进行排序。也就是说...
元素的顺序保持不变
编辑:我得到一个段错误。
编辑#2: 现在没有段错误;原来的问题依然存在。
我正在使用 STLib.h 的 qsort 方法;我使用的比较函数是:
int qcmp6_4(const void *a, const void *b)
{
return (*(struct dstncFreqNode6_4 **)a) -> count - (*(struct dstncFreqNode6_4 **)b) -> count;
}
我似乎无法弄清楚为什么它不能正确排序。我实际上实现了自己的快速排序算法并得到了相同的结果。我现在真的不知道。
如果能得到一些新鲜的、专家的眼光为我指明正确的方向,那就太好了。谢谢。
编辑
抱歉,这是对 qsort 的调用:
qsort(wordCounts, numWords, sizeof(struct dstncFreqNode6_4 *), qcmp6_4);
编辑#2:
按照建议,我将“wordCounts”设为节点指针数组(本文中的所有代码都已更新以反射(reflect)这一点)。所以从本质上讲,BST和数组包含的信息是一样的(实际上数组指针被初始化为BST中对应的指针),只是用途不同。 BST 用于添加新词/更新已遇到词的计数,数组在末尾排序(按每个词的计数)并打印。但是,我遇到了与最初遇到的相同问题:调用 qsort 后数组的顺序保持不变。
最佳答案
在我看来,您正在尝试对节点数组进行排序,每个节点都包含指向数组中其他节点的指针。排序后,这些指针当然会指向错误的数组元素。也许这是你的问题?
顺便说一下,我看到您正在使用 realloc
。每当它必须将分配的数组移动到新位置以满足新的大小要求时,指向数组元素的指针也会出现同样的问题,更糟糕的是:节点指针现在将全部指向到无效地址并使用它们将导致未定义的行为。
一个可能的解决方案是永远不要修改您的原始节点数组,而是制作第二个指向节点的指针数组,并使用比较它们指向的节点的比较函数对该指针数组进行排序到。
关于C(初学者): Why won't my qsort work? 编辑:从一个错误到另一个错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3970760/
我不明白为什么我会从 GHCi 得到以下回复。不是Maybe构造函数? Prelude> :t Maybe :1:1: Not in scope: data constructor `Maybe' P
场景是我在此网站上有不同的访问级别,我有一个适用于所有有效用户的简单登录流程,但是我现在尝试分隔不同的用户以实现对页面的不同访问。 这是我页面开头的代码: // CHECKS IF THE USER
我的任务是:写下数字1-100。如果该数字可以被 3 整除,则将其写入数字“它可以被 3 整除”旁边的控制台。如果数字是 5,也将其写入数字旁边的控制台“它可以被 5 整除”,如果它不能被 3 整除,
我有一堆实现协议(protocol) P 的记录 (A B C)。 我想编写一个方法,该方法将选择一种记录类型,构造它,然后调用它的方法。 例如,如果我有一个记录列表(def types '(A B
我的任务是编写一个程序,根据以下三个因素来预测您的年度燃料使用量汽车加油。我必须使用两个单独的类。这是我的第一个类,名为 AnnualFuelUse。 public class AnnualFuelU
我是 JavaScript 新手。我已经通过 Learning JavaScript (o'reilly) 完成了我的工作,但我只是想制作我的第一个 JavaScript。 我认为最好从事我感兴趣的事
我真的刚刚开始学习如何用 Python 编写代码。我有兴趣 如何重现 u[x,t] 矩阵。我尝试了 return u,它抛出了一个错误。 如果此代码中 for 循环的位置正确并正常运行。 最重要的是,
我不明白 view("") 在作为 Model 对象一部分的以下 javascript 方法中的作用: addView: function(view) { this.views
所以我正在尝试将 AppKit 导入到我的 python 项目中。我正在使用 pyCharm,但每次我尝试导入时,都会收到以下错误消息: You are using pip version 6.0.8
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 5 年前。 Improve this qu
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 2 年前。 Improve
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
好吧,不知道在哪里问这个,但我是一个初学者程序员,使用 Perl。我需要创建一个数组数组,但我不确定使用数组/哈希引用、哈希数组或数组哈希等是否更好。 我需要一组匹配项:@totalmatches 每
我最近开始学习 PHP。我做了一个基本的网站,基本上想给它密码。如果有人能告诉我为什么这不起作用,我将不胜感激。我知道它不起作用,因为我已经尝试过了;我只是不明白为什么。 ... REST OF W
我试图理解 C 中的整个指针和取消引用。我几乎明白了,但遇到了非常简单的代码,结果我不明白: char *ptr = "Characters"; char val = *ptr; char *chrp
首先,我有这个列表(在练习中建议): Members = [('Tessa','G1'),('Evan','G2'),('Tom','G3'), ('Mia','G3'),('Claire','G3'
我有以下列表: listofanimals = ['Dog', 'Cat', 'Frog', 'Tiger', 'Sheep', 'Lion'] 我想根据字典对这个列表进行排序: score_card
1 userID = floatval($userID); 13 } else { 14 $this->userID = floatval(
我是 R 新手,遇到了一段我不理解的代码。更具体地说,我想知道 .Internal做。这是我尝试转换为 Matlab 的示例: dunif 我想知道.Internal和 做。 非常感谢您, 西蒙 最
我是一名优秀的程序员,十分优秀!