- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我已经看了好几个小时了,还是想不通。如果 heapify 函数中的比较更改为大于,则输出按应有的顺序递增。我希望我的列表按降序排序,但它没有使用以下代码给出正确的输出:
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
typedef struct stuff {
char *str;
}stuff_t;
void heapify(stuff_t *stuff_array, int i, int n)
{
stuff_t temp;
int left, right, max;
left = 2*i;
right = left + 1;
max = i;
if (left < n)
if (strtod(stuff_array[left].str, NULL) < strtod(stuff_array[i].str, NULL))
max = left;
if (right < n)
if (strtod(stuff_array[right].str, NULL) < strtod(stuff_array[max].str, NULL))
max = right;
if (max != i)
{
temp = stuff_array[i];
stuff_array[i] = stuff_array[max];
stuff_array[max] = temp;
heapify(stuff_array, max, n);
}
}
void heapsort(stuff_t *stuff_array)
{
short i,N;
stuff_t temp;
N = 0;
while (stuff_array[N].str)
N++;
for (i = (N/2)-1; i >= 0; i--)
heapify(stuff_array, i, N);
for (i = N-1; i >= 1; i--) {
temp = stuff_array[0];
stuff_array[0] = stuff_array[i];
stuff_array[i] = temp;
heapify(stuff_array, 0, i);
}
}
int main (int argc, char* argv[])
{
int i;
stuff_t *s_list = calloc(4, sizeof(stuff_t));
stuff_t *s_list1 = calloc(8, sizeof(stuff_t));
s_list[0].str = "9.3";
s_list[1].str = "9.3";
s_list[2].str = "7.8";
printf("before: ");
for (i = 0; i < 3; i++)
printf("%s, ", s_list[i]);
printf("\n");
heapsort(s_list);
printf("after: ");
for (i = 0; i < 3; i++)
printf("%s, ", s_list[i]);
printf("\n");
s_list1[0].str = "7.5";
s_list1[1].str = "10.0";
s_list1[2].str = "10.0";
s_list1[3].str = "8.3";
s_list1[4].str = "6.5";
s_list1[5].str = "5.0";
s_list1[6].str = "4.6";
printf("before: ");
for (i = 0; i < 3; i++)
printf("%s, ", s_list1[i]);
printf("\n");
heapsort(s_list1);
printf("after: ");
for (i = 0; i < 7; i++)
printf("%s, ", s_list1[i]);
printf("\n");
return 0;
}
程序输出:
// using less than comparison
before: 9.3, 9.3, 7.8,
after: 9.3, 7.8, 9.3,
before: 7.5, 10.0, 10.0,
after: 10.0, 10.0, 8.3, 7.5, 6.5, 4.6, 5.0,
// using greator than comparison
before: 9.3, 9.3, 7.8,
after: 7.8, 9.3, 9.3,
before: 7.5, 10.0, 10.0,
after: 4.6, 5.0, 6.5, 7.5, 8.3, 10.0, 10.0,
最佳答案
如果从 0 开始计数,则不能使用 i*2 和 i*2+1 作为 child 的地址。问题是 2*0 = 0(左 child 将与 parent 相同)。
关于c - Heapsort 按降序排列不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3159979/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!