- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我的结构是这样的:
typedef struct celltag{
char name[11];
double time;
struct celltag *next;
} celltype;
并且这种类型的结构保存在一个链表数组中:
typedef celltype **Hash;
并且两个结构 X 和 Y 被链接到同一个列表中,如果对于某些给定的函数 h(char x[]), h(X->name)=h(Y->name)
。我想说的是,这些结构是按它们的“名称”排序到数组中的。
现在,我必须使用指针数组按结构的“时间”对结构进行排序,这样数组中的第一个指针指向时间最短的结构,第二个指针指向第二小的结构,依此类推。
我该怎么做?我对指针仍然不是很好,所以我根本不知道如何处理这个问题。我尝试查看已在此处发布的类似问题,但这些指针完全让我困惑,我似乎无法让它们适用于我的代码。
例如,如果我有一个函数:
void sort(Hash A, celltype *PArray[MAX]){
}
*PArray[MAX]
是我的指针数组,哈希 A 是存储结构的地方。我该如何编写其余的功能?如何让一个指针指向一个结构体??
最佳答案
如果您仍然卡住,您需要做的概述是遍历哈希表(即遍历每个桶,然后遍历每个桶中包含的列表的每个节点,以使您的指针数组指向每个哈希表中的条目。哈希表的键控方式无关紧要,您所关心的只是使 PArray
中的每个使用指针指向 celltype
。
我假设您知道如何遍历哈希表。只需从 0
循环到 ht_size
(其中 htsize
是哈希表中桶的数量,例如数组元素)。然后,您只需声明一个 celltype *p
指针并迭代存储桶条目指向的列表(它可以只是单个 celltype*
,其中 next
指针为 NULL
,或者它可以是基于哈希冲突的任何数字,该哈希冲突导致多个 celltype*
解析到桶 hashtable[x]
)
一旦您填充了 PArray
以便一些指针 nptr
现在指向哈希表中的 celltype*
,剩下的就是调用 qsort
以按 celltype->time
成员对指针进行排序。唯一的技巧是您必须编写 compare 函数来比较相邻的 celltype->time
值。
qsort
比较函数原型(prototype):
int compare (const void *ap, const void *bp);
(其中 a
和 b
是指向被比较的相邻元素的指针。我添加 p
只是为了将它们表示为指针)
我们在排序什么?指向 celltype
的指针数组。所以数组的每个成员已经是一个指针,如果每个参数都是指向相邻元素的指针,那么每个参数将代表一个指向 celltype
的指针。
一旦您确定了您的比较 指针所代表的内容,只需解除对参数的引用即可允许您访问每个结构中的 time
成员。当每个参数都是一个指向指针的指针时,您可以将参数转换为 type * const *
并取消引用以提供一个指向类型的指针,您可以使用它来比较 time
值,例如
/* qsort compare for array of pointers to celltype */
int compare (const void *ap, const void *bp)
{
celltype *a = *((celltype * const *)ap);
celltype *b = *((celltype * const *)bp);
return (a->time > b->time) - (a->time < b->time);
}
(对于任何数字类型,返回两个条件 (a > b) - (a < b)
的结果以进行升序排序,只是避免了如果返回 a - b
可能导致的潜在溢出,例如,其中 a
可能是一个大的负值,而 b
可能是一个大的正值溢出)
虽然您没有显示 A
是如何声明的,但您确实显示了 typedef
的 Hash
,当取消引用时将导致指向 celltype
的指针。使用 ht_size
表示哈希表中的桶数,您的 sort
函数将类似于:
void sort(Hash A, celltype *PArray[MAX]){
size_t nptr = 0;
for (size_t i = 0; i < ht_size; i++) { /* loop over buckets */
celltype *p = A[i]; /* pointer to celltype */
while (p) { /* iterate over all chained nodes */
PArray[nptr++] = p; /* assigning pointer to PArray */
p = p->next
}
}
qsort (PArray, ntpr, sizeof *PArray, compare); /* call qsort */
}
简而言之就是这样。如果您仍然无法理解上面部分示例中的 qsort
概念,那么一个简短的完整示例应该可以消除混淆,例如
#include <stdio.h>
#include <stdlib.h>
typedef struct celltag{
char name[11];
double time;
struct celltag *next;
} celltype;
int compare (const void *ap, const void *bp)
{
celltype *a = *((celltype * const *)ap);
celltype *b = *((celltype * const *)bp);
return (a->time > b->time) - (a->time < b->time);
}
int main (void) {
celltype c1 = { .name = "three", .time = 127.21 },
c2 = { .name = "one", .time = 127.1 },
c3 = { .name = "two", .time = 127.19 },
*pc[] = { &c1, &c2, &c3 };
size_t n = sizeof pc / sizeof *pc;
qsort (pc, n, sizeof *pc, compare);
for (size_t i = 0; i < n; i++)
printf ("%-5s %6.2f\n", pc[i]->name, pc[i]->time);
}
示例使用/输出
$ ./bin/qsort_ptp_struct
one 127.10
two 127.19
three 127.21
检查一下,如果您还有其他问题,请告诉我。
关于c - 指向结构的指针数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54527437/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!