X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=TP_9%2Fexo2%2Fclist.c;h=afdb00f6c12e84617d2d360dc331c8849dee94a5;hb=954256b7be7394db3b0b64c6a74fb5f79bec8b5e;hp=0aa9e37da73e1271d043a5a82796f75742999754;hpb=0d650b413a907f0fd4e78ee1500c196e9fd41d9f;p=TD_C.git diff --git a/TP_9/exo2/clist.c b/TP_9/exo2/clist.c index 0aa9e37..afdb00f 100644 --- a/TP_9/exo2/clist.c +++ b/TP_9/exo2/clist.c @@ -1,13 +1,15 @@ #include +#include +#include #include "clist.h" link_t* list_new(int value) { - link_t* link_t_new; - link_t_new = malloc(sizeof(link_t)); - link_t_new->value = value; - link_t_new->next = NULL; - return link_t_new; + link_t* link_new; + link_new = malloc(sizeof(link_t)); + link_new->value = value; + link_new->next = NULL; + return link_new; } link_t* list_append(link_t* head, int value) { @@ -32,33 +34,40 @@ link_t* list_prepend(link_t* head, int value) { } link_t* list_insert(link_t* head, unsigned index, int value) { - link_t* link_insrt = list_new(value); - link_t* head_first = head; - //link_t* head_prev = NULL; - link_t* head_next = NULL; - for (unsigned i = 0; i < index; i++) { - head = head->next; + if (index == 0) { + return list_prepend(head, value); + } else if (index == list_count(head)) { + return list_append(head, value); + } else { + link_t* link_insrt = list_new(value); + link_t* head_first = head; + link_t* head_next = NULL; + for (unsigned i = 0; i < index-1; i++) { + head = head->next; + } + head_next = head->next; + head->next = link_insrt; + head = link_insrt; + head->next = head_next; + return head_first; } - //head_prev = head; - head->next = link_insrt; - head_next = head->next; - head = link_insrt; - head->next = head_next; - return head_first; } link_t* list_delete(link_t* head, unsigned index) { - link_t* head_first = head; link_t* head_prev = NULL; link_t* head_next = NULL; + link_t* head_ret = NULL; - if (index == 0) { + if (head == NULL) { + return NULL; + } else if (index == 0) { head_next = head->next; free(head); head = head_next; - return head; + head_ret = head; } else { + link_t* head_first = head; for (unsigned i = 0; i < index-1; i++) { head = head->next; } @@ -68,16 +77,51 @@ link_t* list_delete(link_t* head, unsigned index) { free(head); head = head_prev; head->next = head_next; - return head_first; + head_ret = head_first; + } + if (head_ret != NULL) { + return head_ret; + } else { + return NULL; + } +} + +link_t* list_concat(link_t* first, link_t* second) { + link_t* head_first = first; + + while (first->next != NULL) { + first = first->next; } + first->next = second; + return head_first; +} + +link_t* list_sort(link_t* head) { + int tmp; + bool isswaped; + link_t* head_first = head; + + do { + isswaped = false; + while (head->next != NULL) { + if (head->value > head->next->value) { + tmp = head->value; + head->value = head->next->value; + head->next->value = tmp; + isswaped = true; + } + head = head->next; + } + /* Reloop at the beginning of the list until there's values swaped */ + head = head_first; + } while (isswaped); + return head_first; } unsigned list_count(link_t* head) { - int count = 0; + unsigned count = 0; - if (head == NULL) { return count; } - count = 1; - while (head->next != NULL) { + while (head != NULL) { ++count; head = head->next; } @@ -85,31 +129,47 @@ unsigned list_count(link_t* head) { } void list_set(link_t* head, unsigned index, int value) { + unsigned count = 0; - //FIXME: check for the index value validity - for (unsigned count = 0; count < index; count++) { + while (head != NULL && count < index) { + ++count; head = head->next; } - head->value = value; + if (head != NULL) { head->value = value; } } int list_get(link_t* head, unsigned index) { - - if (index < list_count(head)) { - for (unsigned i = 0; i < index; i++) { - head = head->next; - } + unsigned count = 0; + + while (head != NULL && count < index) { + ++count; + head = head->next; + } + if (head != NULL) { return head->value; - } else { + } else { return -1; } } -void list_clear(link_t* link) { +void list_clear(link_t* head) { + link_t* next_link = NULL; + + while (head != NULL) { + next_link = head->next; + free(head); + head = next_link; + } +} + +void list_display_values(link_t* head) { + unsigned i = 0; - while (link != NULL) { - link_t* next_link = link->next; - free(link); - link = next_link; + printf("------Begin------\n"); + while (head != NULL) { + printf("value at [%d]=%d\n", i, head->value); + head = head->next; + i++; } + printf("------End------\n"); }