c - 按多个参数对链表进行排序

标签 c sorting linked-list

我正在尝试在单链表上使用插入排序,其中每个节点都有多个参数,例如:

typedef struct _node {
    char param1[10];
    char param2[10];
    char param3[10];
    struct _node *next;
} node;

该算法将按 param1 对列表进行排序,如果项目相同,则由 param2 决定顺序,类似地由 param3 决定顺序。 我无法在线找到解决此问题的方法。对于单个参数,我有以下排序算法的实现:

void insertionSort(node **head) {

    //Initialize sorted list
    node *sorted = NULL;
    node *current = *head;

    //Insert every node into sorted list
    while (current != NULL) {
        // Store next for next iteration
        node *next = current->next;

        sortedInsert(&sorted, current);

        // Update current
        current = next;
    }

    //Replace old empty list with sorted list
    *head = sorted;
}

void sortedInsert(node **head, node *new) {
    node *current = *head;
    // Special case for the head
    if (current == NULL || strcmp(current->param1, new->param1) >= 0) {
        new->next = current;
        *head = new;
    }

    else {
        while (current->next!=NULL && strcmp(current->next->param1, new->param1) < 0){
            current = current->next;
        }

        new->next = current->next;
        current->next = new;
    }
}

我的猜测是我必须创建一个比较函数而不是以下位,可能是一个返回 0 或 1 的整数函数,对应于这两种情况:

current->param1 >= new->param1
current->next->param1 < new->param1

但是,我无法想出这样的功能。谁能帮我解决这个问题?

最佳答案

一个排序例程,通过比较来决定之前或之后的内容。如果比较是在一个函数中完成的,那么元素的顺序由返回决定(例如小于零(一般为-1)、零、大于零(一般为的返回>1))。

如果您按主要参数排序并遇到等价项,则按次要字符串进行比较并使用这些结果进行放置。在大多数情况下,比较函数将采用指向每个被比较节点的空指针。通过这种方式,您将可以访问排序函数中的主要和次要字符串。只需在排序函数中包含二次比较,以防第一次比较的结果为零,并根据二次比较的结果返回 (-1, 0, 1)。

关于c - 按多个参数对链表进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33728844/

相关文章:

c - C 中的 UDP 发送和接收

C语言中统计字符串中单词的合适首字母

c# - "The ORDER BY sort key(s) type must be order-comparable"动态数据

c++ - 什么时候修改链表?

c++ - 使用 cerr 修复的链表段错误

c - 反汇编 HTTP 响应 (C)

C# 或 C/C++ 如何从客户端接收数据包,过滤并将它们重定向到服务器,从服务器接收并发送给客户端

java - 按它们包含的最高值对 multimap 的键进行排序

javascript - 通过粘性和默认排序功能对数组进行排序

java - 如何将显示方法添加到仅显示列表中第一个和最后 10 个项目的 Java 链表实现?