protected override bool InsertarEn(int prmIndice, Tipo prmItem)
        {
            clsNodoDobleEnlazado <Tipo> varNodoNuevo = new clsNodoDobleEnlazado <Tipo>(prmItem);

            #region Insertar el primer elemento
            if (EstaVacia())
            {
                atrNodoPrimero = varNodoNuevo;
                atrNodoUltimo  = atrNodoPrimero;
                atrNodoUltimo.ponerAnterior(atrNodoPrimero);
                atrNodoPrimero.ponerSiguiente(atrNodoUltimo);
                atrLongitud++;
                return(true);
            }
            #endregion
            #region Insertar en la primera posicion
            if (prmIndice == 0)
            {
                varNodoNuevo.ponerSiguiente(atrNodoPrimero);
                atrNodoPrimero.ponerAnterior(varNodoNuevo);
                atrNodoPrimero = varNodoNuevo;
                atrLongitud++;
                return(true);
            }
            #endregion
            #region Insertar en la ultima posicion
            if (prmIndice == atrLongitud)
            {
                atrNodoUltimo.ponerSiguiente(varNodoNuevo);
                varNodoNuevo.ponerAnterior(atrNodoUltimo);
                atrNodoUltimo = varNodoNuevo;
                atrLongitud++;
                return(true);
            }
            #endregion
            #region Insertar en cualquier posicion
            if (EsValido(prmIndice))
            {
                clsNodoDobleEnlazado <Tipo> varNodoActual = atrNodoPrimero;
                for (int varIndice = 1; varIndice < prmIndice - 1; varIndice++)
                {
                    varNodoActual = varNodoActual.darSiguiente();
                }
                varNodoNuevo.ponerSiguiente(varNodoActual.darSiguiente());
                varNodoNuevo.ponerAnterior(varNodoActual);
                varNodoActual.ponerSiguiente(varNodoNuevo);
                atrLongitud++;
                return(true);
            }
            #endregion
            return(false);
        }
 protected override bool ExtraerEn(int prmIndice, ref Tipo prmItem)
 {
     if (!EstaVacia())
     {
         #region extraer en 0
         if (prmIndice == 0)
         {
             prmItem = atrNodoPrimero.darItem();
             if (atrLongitud == 1)
             {
                 atrNodoPrimero = null;
                 atrNodoUltimo  = null;
                 atrLongitud--;
                 return(true);
             }
             atrNodoPrimero = atrNodoPrimero.darSiguiente();
             atrNodoPrimero.ponerAnterior(null);
             atrLongitud--;
             return(true);
         }
         #endregion
         #region Extraer en longitud
         if (prmIndice == atrLongitud - 1)
         {
             prmItem       = atrNodoUltimo.darItem();
             atrNodoUltimo = atrNodoUltimo.darAnterior();
             atrNodoUltimo.ponerSiguiente(null);
             atrLongitud--;
             return(true);
         }
         #endregion
         #region extraer en n posicion
         if (EsValido(prmIndice))
         {
             clsNodoDobleEnlazado <Tipo> varNodoExtraido = atrNodoPrimero;
             for (int varIndice = 1; varIndice < prmIndice; varIndice++)
             {
                 varNodoExtraido = varNodoExtraido.darSiguiente();
             }
             prmItem = varNodoExtraido.darItem();
             varNodoExtraido.darSiguiente().ponerAnterior(varNodoExtraido.darAnterior());
             varNodoExtraido.darAnterior().ponerSiguiente(varNodoExtraido.darSiguiente());
             varNodoExtraido.ponerSiguiente(null);
             varNodoExtraido.ponerAnterior(null);
             atrLongitud--;
             GC.Collect();
             return(true);
         }
         #endregion
     }
     return(false);
 }
Пример #3
0
        protected override bool InsertarEn(int prmIndice, Tipo prmItem)
        {
            clsNodoDobleEnlazado <Tipo> varNodoNuevo = new clsNodoDobleEnlazado <Tipo>(prmItem);

            if (EstaVacia())
            {
                atrNodoPrimero = varNodoNuevo;
                atrNodoUltimo  = varNodoNuevo;
                atrNodoPrimero.ponerSiguiente(atrNodoUltimo);
                atrNodoUltimo.ponerAnterior(atrNodoPrimero);
                atrLongitud++;
                return(true);
            }
            if (prmIndice == 0)
            {
                varNodoNuevo.ponerSiguiente(atrNodoPrimero);
                atrNodoPrimero.ponerAnterior(varNodoNuevo);
                atrNodoPrimero = varNodoNuevo;
                atrLongitud++;
                return(true);
            }
            if (prmIndice == atrLongitud)
            {
                //atrNodoUltimo.ponerSiguiente(varNodoNuevo);
                //varNodoNuevo.ponerAnterior(atrNodoUltimo);
                atrNodoUltimo.ConectarSiguiente(varNodoNuevo);
                atrNodoUltimo = varNodoNuevo;
                atrLongitud++;
                return(true);
            }
            if (IrIndice(prmIndice - 1))
            {
                //varNodoNuevo.ponerSiguiente(atrNodoActual);
                //varNodoNuevo.ponerAnterior(atrNodoActual.darAnterior());
                //atrNodoActual.darAnterior().ponerSiguiente(varNodoNuevo);
                //atrNodoActual.ponerAnterior(varNodoNuevo);
                atrNodoActual.ConectarSiguiente(varNodoNuevo);
                atrLongitud++;
                return(true);
            }
            return(false);
        }
 protected override bool ExtraerEn(int prmIndice, ref Tipo prmItem)
 {
     if (EsValido(prmIndice))
     {
         clsNodoDobleEnlazado <Tipo> varNodoExtraido = atrNodoPrimero;
         for (int varIndice = 1; varIndice <= prmIndice; varIndice++)
         {
             varNodoExtraido = varNodoExtraido.darSiguiente();
         }
         prmItem = varNodoExtraido.darItem();
         varNodoExtraido.darAnterior().ponerSiguiente(varNodoExtraido.darSiguiente());
         varNodoExtraido.darSiguiente().ponerAnterior(varNodoExtraido.darAnterior());
         varNodoExtraido.ponerAnterior(null);
         varNodoExtraido.ponerSiguiente(null);
         varNodoExtraido = null;
         atrLongitud--;
         return(true);
     }
     return(false);
 }
        protected override bool InsertarEn(int prmIndice, Tipo prmItem)
        {
            clsNodoDobleEnlazado <Tipo> varNodoNuevo = new clsNodoDobleEnlazado <Tipo>(prmItem);

            if (EstaVacia())
            {
                atrNodoPrimero = varNodoNuevo;
                atrNodoUltimo  = varNodoNuevo;
                atrNodoPrimero.ponerSiguiente(atrNodoUltimo);
                atrNodoUltimo.ponerAnterior(atrNodoPrimero);
                atrLongitud++;
                return(true);
            }
            if (prmIndice == 0)
            {
                varNodoNuevo.ponerSiguiente(atrNodoPrimero);
                atrNodoPrimero.ponerAnterior(varNodoNuevo);
                atrNodoPrimero = varNodoNuevo;
                atrLongitud++;
                return(true);
            }
            if (EsValido(prmIndice))
            {
                clsNodoDobleEnlazado <Tipo> varNodoActual = atrNodoPrimero;
                for (int varIndice = 1; varIndice < prmIndice; varIndice++)
                {
                    varNodoActual = varNodoActual.darSiguiente();
                }
                varNodoNuevo.ponerSiguiente(varNodoActual);
                varNodoNuevo.ponerAnterior(varNodoActual.darSiguiente());
                varNodoActual.darAnterior().ponerSiguiente(varNodoNuevo);
                varNodoActual.ponerAnterior(varNodoNuevo);
                atrLongitud++;
                return(true);
            }
            return(false);
        }