From 360be3c54de2c3b7e47fc1f801a89b735c0cc141 Mon Sep 17 00:00:00 2001
From: "pierre.kunzli" <pierre.kunzli@hesge.ch>
Date: Wed, 23 Feb 2022 07:51:43 +0100
Subject: [PATCH] Re re correction recherche

---
 slides/cours_15.md | 15 +++++++++++----
 1 file changed, 11 insertions(+), 4 deletions(-)

diff --git a/slides/cours_15.md b/slides/cours_15.md
index d463f69..0cfc64d 100644
--- a/slides/cours_15.md
+++ b/slides/cours_15.md
@@ -790,7 +790,7 @@ typedef struct _node {
 typedef node* tree_t;
 tree_t search(key_t key, tree_t tree) {
     tree_t current = tree;
-    while (NULL != current && !success) {
+    while (NULL != current) {
         if (current->key > X) {
             current = current->gauche;
         } else if (current->key < X){
@@ -877,13 +877,18 @@ int arbre_size(tree_t tree) {
 ```
 arbre position(arbre, clé)
     si est_non_vide(arbre)
+        si clé < clé(arbre)
+            suivant = gauche(arbre)
+        sinon
+            suivant = droite(arbre)
         tant que clé(arbre) != clé && est_non_vide(suivant)
+            arbre = suivant
             si clé < clé(arbre)
                 suivant = gauche(arbre)
             sinon
                 suivant = droite(arbre)
-            arbre = suivant
-    returne arbre
+            
+    retourne arbre
 ```
 
 # Pseudocode d'insertion (2/2)
@@ -917,10 +922,12 @@ ajout(arbre, clé)
 tree_t position(tree_t tree, key_t key) {
     tree_t current = tree;
     if (NULL != current) {
+        tree_t subtree = key > current->key ? current->right :
+        current->left;
         while (key != current->key && NULL != subtree) {
+            current = subtree;
             subtree = key > current->key ? current->right :
             current->left;
-            current = subtree;
         }
     }
     return current;
-- 
GitLab