+ /* Caso 2c debo hacer un merge de la clave con hijo izq y der */
+ node_y = b_plus_leer_nodo(idx,nodo->hijos[i]);
+ node_z = b_plus_leer_nodo(idx,nodo->hijos[i+1]);
+ /* Bajo la clave Key a NodoY y muevo todo lo de NodoZ a NodoY */
+ /* Si es nivel mayor a 1, bajo clave pues no esta en NodoZ, otherwise no bajo */
+ if (nodo->nivel > 1) {
+ nivel_mayor1 = 1;
+ node_y->claves[minclaves] = key;
+ }
+ for (j = 0; j < minclaves; ++j) node_y->claves[j+minclaves+nivel_mayor1] = node_z->claves[j];
+ for (j = 0; j < minclaves+1; ++j) node_y->hijos[j+minclaves+nivel_mayor1] = node_z->hijos[j];
+ node_y->cant_claves = minclaves*2+nivel_mayor1;
+ /* Shifteo en el nodo padre NODO, para quitar la que bajo */
+ for (j = i; j < nodo->cant_claves-1; ++j) {
+ nodo->claves[j] = nodo->claves[j+1];
+ nodo->hijos[j+1] = nodo->hijos[j+2];
+ }
+ nodo->cant_claves--;
+ b_plus_grabar_nodo(idx,nodo,num_node);
+ b_plus_grabar_nodo(idx,node_y,nodo->hijos[i]);
+ b_plus_destruir_nodo(node_y);
+ b_plus_destruir_nodo(node_z);
+ /* Elimino recursivamente Key de NodeY, entrando por ese subtree */
+ emufs_b_plus_eliminar(idx,key,nodo->hijos[i]);
+ }