[英]Linked list QuickSort C
我編寫了一些簡單的代碼,對包含密碼的列表以及該密碼的使用頻率進行了排序。 問題是,讀取文本文件后,節點未連接在一起。 我不明白為什么。 它僅保留最后一個值。
#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;
printf("%s %d \n",le->passwort, le->haufigkeit);
}
else {
le->next = mylist-> first;
mylist->first= le;
}
// printf("%s %d \n",le->passwort, &le->haufigkeit);
}
// 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,"rb");
assert(f != NULL);
list_element* temp = malloc(sizeof(list_element));// * Speicher allozieren
while (fscanf(f,"%s %d",temp->passwort, &temp-> haufigkeit) != EOF)
{
fscanf(f,"%s %d",temp->passwort, &temp-> haufigkeit);// * Daten in list_element einlesen
printf("%s %d \n",temp->passwort, temp->haufigkeit);
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;
printf("hi");
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;
}
// Hauptfunktion des quicksort Algorithmus
void qsort_list(list* mylist){
// HIER Code einfügen
// list liste= mylist;
list right;
list left;
init_list(&right);
init_list(&left);
list_element* pivot;
printf("hi11");
if (mylist->last != mylist->first){
printf("d1 \n");
pivot = partition(mylist, &left, &right );
printf("pivot %s %d \n",pivot->passwort, pivot->haufigkeit);
qsort_list(&left);
qsort_list(&right);
/*
if(left.first == NULL){
pivot->next = right.first;
mylist->first = pivot;
mylist->last = right.last;
}
else if(right.first == NULL){
left.last-> next = pivot;
mylist->first = left.first;
mylist->last = pivot;
}
else{
left.last->next=pivot;
pivot->next = right.first;
mylist->first = left.first;
mylist->last = right.last;
}
printf("pivot %s %d \n",pivot->passwort, pivot->haufigkeit);
}
/* mylist->first = left-> first;
mylist->last=right->last;
pivot->next=right->last;
left.last->next=pivot;
pivot->next=right.first;
*/
if(left.first == NULL) {
// Special
left.first = pivot;
mylist->first = left.first;
} else {
// REGULAR
mylist->first = left.first;
left.last->next = pivot;
}
if(right.first == NULL) {
// Special
pivot->next = right.first;
mylist->last = pivot;
} else {
// Regular
pivot->next = right.first;
mylist->last = right.last;
}
}
}
// Liste ausgeben
void print_list(list* mylist){
list_element* current = mylist-> first;
while(current != NULL){
printf("%s %d \n",current->passwort,current->haufigkeit);
current=current->next;
}
}
// 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;
}
列表txt的格式為“密碼頻率”,例如
daniel 27720
welcome 22204
adobeadobe 27840
superman 24499
7777777 19818
liverpool 18008
princess 28132
1qaz2wsx 22180
您的問題始於read_data()
:您僅為一個list_element
( temp
)分配了回憶,並用從數據文件中讀取的每條記錄覆蓋了其內容。 您需要為每個分配單獨的list_element
。
問題是當next不為NULL時,您的insert_front將不起作用。 您最終將看到的列表設置為NULL。 您也無法知道指向該元素的內容。 您的列表結構應包含一個上一個指針和一個下一個指針。
typedef struct list_element{
char passwort[100];
int haufigkeit;
struct list_element *prev;
struct list_element *next;
} list_element;
這是您的程序insert_front方法的更新版本:
void insert_front(list_element* le, list* mylist)
{
if(mylist->first == NULL){
mylist->first=le;
mylist->last=le;
le->prev = NULL;
printf("%s %d \n",le->passwort, le->haufigkeit);
}
else {
if (le->prev != NULL) {
le->prev->next = le->next;
}
le->next = mylist-> first;
mylist->prev = le
mylist->first= le;
}
// printf("%s %d \n",le->passwort, &le->haufigkeit);
}
這應該可以解決您遇到的問題。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.