gpt4 book ai didi

c - 单链表上的快速排序

转载 作者:行者123 更新时间:2023-11-30 21:25:44 26 4
gpt4 key购买 nike

我正在尝试为单链表上的 QUICKSORT 编写一个简单的 C 代码。程序将获得一个txt文件,其中包含密码和使用该密码的频率。程序应按顺序对密码进行排序。有人能猜出这里出了什么问题吗?

#include <stdio.h>
#include <stdlib.h>
#include <assert.h>


typedef struct list_element{
char passwort[100];
int haufigkeit;
struct list_element *next;
} list_element;

typedef struct list{
list_element *first;
list_element *last;
} list;


void init_list(list* mylist)
{
mylist->first=NULL;
mylist->last=NULL;
}


// Diese Funktion fügt Listenelemente am Anfang der Liste an
void insert_front(list_element* le, list* mylist)
{
if(mylist->first == NULL){
le->next = mylist-> first;
mylist->first=le;
mylist->last=le;
}
else {
le->next = mylist-> first;
mylist->first= le;
}
}

// Speicher für Listenelemente wieder freigeben
void free_list(list* mylist)
{
free((mylist)->first);
free(mylist);
mylist=NULL;
}


// Namen, Zahlen Paare in Liste einlesen
void read_data(char* filename, list* mylist)
{
assert(mylist != NULL);
FILE* f=fopen(filename,"r");
assert(f != NULL);
while (1)
{
list_element* temp = malloc(sizeof(list_element));// * Speicher allozieren
fscanf(f,"%s %d",temp->passwort, &temp-> haufigkeit);// * Daten in list_element einlesen
insert_front(temp, mylist); // * insert_front benutzen um list_element in Liste einzufügen
}
fclose(f);
}

// Pivot finden, das die Liste aufteilt
list_element* partition( list* input, list* left, list* right ){
list_element* pivot= input->first;

while(input->first != input->last){
list_element *i;
for(i=input->first; i != NULL; i=i->next){
if ((i -> haufigkeit) < (pivot -> haufigkeit)){
insert_front( i, left);
}
else{
insert_front( i, right);
}
}
}
return pivot;
}

void print_list(list* mylist){

list_element* current =mylist-> first;
while(current != NULL){
printf("%d %c \n",current->passwort,current->haufigkeit);
current=current->next;
}
}
// Hauptfunktion des quicksort Algorithmus
void qsort_list(list* mylist){
// HIER Code einfügen
// list liste= mylist;
list *right;
list *left;
list_element* pivot;
while(mylist->first != mylist->last){
partition(mylist, left, right );
qsort_list(left);
qsort_list(right);
}
}

// Liste ausgeben

// Argumente einlesen, Liste kreieren, verarbeiten und ausgeben
int main(int argc, char** args)
{
if (argc != 2)
{
printf("Nutzung: %s <Dateiname>\n",args[0]);
return 1;
}
list mylist;
init_list(&mylist);
read_data(args[1],&mylist);
qsort_list(&mylist);
printf("Sortierte Liste:\n");
print_list(&mylist);
free_list(&mylist);
return 0;
}

最佳答案

您打算什么时候中断此代码片段?

while (1)
{
list_element* temp = malloc(sizeof(list_element));// * Speicher allozieren
fscanf(f,"%s %d",temp->passwort, &temp-> haufigkeit);// * Daten in list_element einlesen
insert_front(temp, mylist); // * insert_front benutzen um list_element in Liste einzufügen
}

PS:发表德国评论是没有意义的。请缩进代码并删除/翻译注释

关于c - 单链表上的快速排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27444559/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com