- 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/
我正在尝试对这个字符串列表进行排序:["a", "z", "b"]。所以答案应该是 ["a", "b", "z"]。但是,当我尝试使用 C 的 qsort() 时,没有任何 Action !我做错了什
我尝试使用 qsort 创建一些基本代码来对字符串数组进行排序,但根据 gdb,它在 qsort 中崩溃了: #include #include static int pcmp(const voi
我想使用 qsort(...) 对 2D int 数组进行排序,但我的比较函数似乎是错误的。 qsort的参数如下: qsort(void *base, size_t nitems, size_t s
我一直在寻找一种方法来对 C 中的数组子集进行排序,而无需将元素移动到临时数组并将它们复制回来。我可能对 qsort 理解不好,但我认为下面的代码应该可以工作: qsort(&my_struct_ar
我正在使用标准 c 库的 qsort 函数对组织在数组中的数百万个结构进行排序。我试图通过创建具有相同长度的结构指针数组来优化性能。与我的预期相反,第二个变体的执行时间较慢: qsort 结构数组:1
我成功地对结构数组进行了排序,其中每个结构仅包含一个 char 字符串。然而,我的问题是,对于大约的结构数组。 900,000 个元素,qsort 比我预期的要长很多(qsort 需要大约 2 分钟来
这个问题在这里已经有了答案: How to qsort an array of pointers to char in C? (8 个答案) 关闭 5 年前。 我尝试使用 qsort 对字符串数组进
我正在尝试重构一个当前是独立 C 程序的实用程序,以便我可以创建一个可重用的库。它包括根据全局数组中的相应值对数组进行排序的步骤。 // Global lookup table double *rat
我尝试对下面的一个struct进行排序,目的是对它们的错误率进行排序,同时保留sid和did的信息。虽然没有编译错误,但我在运行时遇到段错误。我想知道出了什么问题.... #include #inc
我正在尝试创建一个函数模板,该模板接收一个数组作为输入并对它进行排序。为了对其进行排序,我想我可以使用C++标准库的头文件qsort()中包含的cstdlib函数。 qsort()函数需要将比较器函数
#include #include #include int sortstring(const void *str1, const void *str2) { const char *r
我正在尝试对一个名为 results 的 struct run 数组进行排序,但是当我打印该数组时,没有任何排序。看看这个: struct run { char name[20], weekday
我尝试对下面的一个struct进行排序,目的是对它们的错误率进行排序,同时保留sid和did的信息。虽然没有编译错误,但我在运行时遇到段错误。我想知道出了什么问题.... #include #inc
考虑一个结构指针数组。以下代码取自您可能会找到的示例 here 。我想要为这两排铸件进行移植。我对这种“双重类型转换”不熟悉。 int myptrstructcmp(const void *p1, c
为什么我们在使用qsort()时,int(*compar)(const void*,const void*)没有添加任何参数,却也能完成它们的功能呢? 比如这样: double vals[NUM];
void qsort ( void* base, size_t num, size_t size, int (*compar)(const void*,const vo
嗨,我是学习 C 编程语言的新手,很难理解这个问题。我想对指向 struct[person] 指针数组的双指针进行排序。我需要根据多个标准对结构指针进行排序。 (年龄按升序排列,姓名和高度均按降序排列
我想对数组的特定列进行排序,但必须相应地移动其他元素例如 UNSORTED ARRAY 40 2 30 6 20 1 REQUIRED SORTED ARRAY 20 1 30 6 40 2 如果不能
假设我们有一个结构: struct product { char name[30]; float price; }; 我想首先使用 qsort 按价格对其进行排序,如果价
这个问题已经有答案了: What sorting algorithm does qsort use? (3 个回答) 已关闭 9 年前。 该功能是否qsort()在stdlib.h实际上使用快速排序算
我是一名优秀的程序员,十分优秀!