以下是一个示例代码,用于按照结构体数组中的两个键进行排序:
#include
typedef struct {
int key1;
int key2;
// 可以添加其他成员
} Struct;
void swap(Struct* a, Struct* b) {
Struct temp = *a;
*a = *b;
*b = temp;
}
int compare(Struct a, Struct b) {
if (a.key1 != b.key1) {
return a.key1 - b.key1;
} else {
return a.key2 - b.key2;
}
}
void bubbleSort(Struct arr[], int n) {
int i, j;
for (i = 0; i < n-1; i++) {
for (j = 0; j < n-i-1; j++) {
if (compare(arr[j], arr[j+1]) > 0) {
swap(&arr[j], &arr[j+1]);
}
}
}
}
int main() {
Struct arr[] = {{3, 4}, {1, 2}, {5, 6}, {2, 1}, {4, 3}};
int n = sizeof(arr) / sizeof(arr[0]);
printf("Before sorting:\n");
for (int i = 0; i < n; i++) {
printf("(%d, %d) ", arr[i].key1, arr[i].key2);
}
bubbleSort(arr, n);
printf("\n\nAfter sorting:\n");
for (int i = 0; i < n; i++) {
printf("(%d, %d) ", arr[i].key1, arr[i].key2);
}
return 0;
}
这个示例代码演示了如何使用冒泡排序对结构体数组进行排序。在排序函数中,使用了compare
函数来比较两个结构体的键值,并在需要时使用swap
函数来交换结构体的位置。
上一篇:按两个分组变量汇总数据