我有一个这个结构的列表,我想根据 draw_number 的值对列表进行排序,并且该列表有一个指向列表第一个结构的指针 front 和一个指向列表最后一个结构的指针后.我发现了许多用于排序列表的代码,但我无法为我的代码完成我的工作。结构是:
typedef struct itm{
int draw_number;
char date[11];
char temi[6];
struct itm *next;
}item;
我有一个这个结构的列表,我想根据 draw_number 的值对列表进行排序,并且该列表有一个指向列表第一个结构的指针 front 和一个指向列表最后一个结构的指针后.我发现了许多用于排序列表的代码,但我无法为我的代码完成我的工作。结构是:
typedef struct itm{
int draw_number;
char date[11];
char temi[6];
struct itm *next;
}item;
最简单的将是冒泡排序。
item* sort(item *start){
item *node1,*node2;
int temp;
for(node1 = start; node1!=NULL;node1=node1->next){
for(node2 = start; node2!=NULL;node2=node2->next){
if(node2->draw_number > node1->draw_number){
temp = node1->draw_number;
node1->draw_number = node2->draw_number;
node2->draw_number = temp;
}
}
}
return start;
}