[Optimisation] singly linked list one pass
Bonjour,
ca fait longtemps que j ai pas touche du C ou du C++, et la j ai besoin de faire des exercices pour me rafraichir la memoire :oops: .
Je dois ecrire une fonction qui retourne le 5eme avant dernier element d une liste chainee simple en une seule iteration.
J ai ecris un petit bout, mais je ne suis pas du tout fier de moi meme, c est la premiere pense que j ai eu.
Voila mon bout de code :oops:
Code:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30
|
int sll_get_five_before_Last(sll_s *p_sll){
int p = 0, i =5;
int temp[5];
if(p_sll){
p_sll->list = p_sll->p_start->next;
while(p_sll->list != NULL){
if(p-5 >= 0){
for(i=0 ;i<4 ; i++){
temp[i]=temp[i+1];
}
temp[4] = p_sll->list->value;
}else{
temp[p] = p_sll->list->value;
}
p_sll->list = p_sll->list->next;
p++;
}
if(p-5>= 0){
return temp[0];
}else{
//contains less than 5 elements
return NULL;
}
}else{
return NULL;
}
} |
Merci je suis ouvert a toute optimisation, juste des petites suggestions me suffisent...
Cheers,