En C

La déclaration des structures/fonctions : listsimple.h

typedef struct cell {
  int value;
  struct cell* next;
} Cell;

typedef struct list {
  Cell* head;
  int size;
} List;

List* listCreate();
Cell* listFind(List* l, int value);
Cell* listGet(List* l, int index);
Cell* listAppend(List* l, int value);
Cell* listInsert(List* l, int value, int index);
Cell* listReplace(List* l, int value, int index);
Cell* listRemoveAt(List* l, int index);
Cell* listRemove(List* l, int value);
void listPrint(List* l);

la définition des fonctions : listsimple.c

#include <stdio.h>
#include <stdlib.h>
#include "listsimple.h"
 
List* listCreate() {
  List* l = (List*)malloc(sizeof(List));
  if (l != NULL) {
    l->head = NULL;
    l->size = 0;
  }
  return l;
}
 
Cell* listFind(List* l, int value) {
 
  Cell* cell = l->head;
  while ((cell != NULL) && (cell->value != value)) {
    cell = cell->next;
  }
  return cell;
}
 
Cell* listGet(List* l, int index) {
 
  Cell* cell = l->head;
 
  // A COMPLETER
 
  return cell;
}
 
Cell* listAppend(List* l, int value) {
  Cell* cell = NULL;
  Cell* new = NULL;
  new = (Cell*)malloc(sizeof(Cell));
  new->next = NULL;
  new->value = value;
  if (l->size == 0) {
    l->head = new;
  }
  else {
    cell = listGet(l,l->size-1);
    cell->next = new;
  }
  l->size += 1;
  return new;
}
 
Cell* listInsert(List* l, int value, int index) {
  Cell* cell = NULL;
  Cell* new = NULL;
 
  // A COMPLETER
 
  return new;
}
 
Cell* listReplace(List* l, int value, int index) {
 
  Cell* cell = NULL;
 
  // A COMPLETER
 
  return cell; 
}
 
Cell* listRemoveAt(List* l, int index) {
 
  Cell* cell = NULL;
  Cell* tmp = NULL;
  if (index >= l->size) {
    return;
  }
  else if (index == 0) {
    tmp = l->head;
    l->head = l->head->next;
  }
  else {
    cell = listGet(l,index-1);
    tmp = cell->next;
    cell->next = tmp->next;
  }
  l->size -= 1;
  return tmp;
}
 
Cell* listRemove(List* l, int value) {
 
  Cell* cell = l->head;
 
  // A COMPLETER
 
  return cell;
}
 
void listPrint(List* l) {
 
  Cell* cell = l->head;
  while (cell != NULL) {
    printf("%d -> ",cell->value);
    cell = cell->next;
  }
  printf("\\n");
}

Un programme de test : testlist.c

Création de l'exécutable (compilation + édition de liens) : gcc listsimple.c testsimple.c -o testimple