按多个参数对链表进行排序
Sorting linked list by multiple parameters
我正在尝试在单链表上使用插入排序,其中每个节点都有多个参数,比如:
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
但是,我想不出这样的功能。谁能帮我解决这个问题?
一个排序例程,通过比较来决定之前或之后的内容。如果在函数中进行比较,那么元素的顺序由return决定(例如小于零(一般-1
)、零、大于零(一般是return 1
))。
如果您按主要参数排序并遇到等价项,则按次要字符串进行比较,并将这些结果用于放置。在大多数情况下,比较函数将采用指向每个被比较节点的空指针。通过这种方式,您将可以访问排序函数中的主要和次要字符串。只需在您的排序函数中包含二次比较,以防第一次比较的结果等于零,并且 return (-1, 0, 1
) 基于该二次比较的结果。
我正在尝试在单链表上使用插入排序,其中每个节点都有多个参数,比如:
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
但是,我想不出这样的功能。谁能帮我解决这个问题?
一个排序例程,通过比较来决定之前或之后的内容。如果在函数中进行比较,那么元素的顺序由return决定(例如小于零(一般-1
)、零、大于零(一般是return 1
))。
如果您按主要参数排序并遇到等价项,则按次要字符串进行比较,并将这些结果用于放置。在大多数情况下,比较函数将采用指向每个被比较节点的空指针。通过这种方式,您将可以访问排序函数中的主要和次要字符串。只需在您的排序函数中包含二次比较,以防第一次比较的结果等于零,并且 return (-1, 0, 1
) 基于该二次比较的结果。