Пример #1
0
        public void SortAscendElem()
        {
            DoubleNode tmpListFirst = null;
            DoubleNode tmpListLast  = null;

            for (int i = 0; i < Length; i++)
            {
                DoubleNode current = root;
                DoubleNode min     = root;


                while (current != null)
                {
                    if (current.Value < min.Value)
                    {
                        min = current;
                    }
                    current = current.Next;
                }
                if (root == end)
                {
                    root = null;
                    end  = null;
                }
                else if (min == root)
                {
                    root.Next.Previous = null;
                    root = root.Next;
                }
                else if (min == end)
                {
                    end.Previous.Next = null;
                    end = end.Previous;
                }
                else
                {
                    min.Previous.Next = min.Next;
                    min.Next.Previous = min.Previous;
                }

                if (tmpListFirst != null)
                {
                    tmpListLast.Next = min;
                    min.Previous     = tmpListLast;
                    tmpListLast      = tmpListLast.Next;
                }
                else
                {
                    tmpListFirst = min;
                    tmpListLast  = tmpListFirst;
                }
            }
            root = tmpListFirst;
            end  = tmpListLast;
        }
Пример #2
0
 public void DelFromEndNElem(int n) // удаление из конца n-элементов
 {
     if (Length > n)
     {
         for (int i = 0; i < n; i++)
         {
             end      = end.Previous;
             end.Next = null;
             Length--;
         }
     }
 }
Пример #3
0
 public void DelFromBeginNElem(int n) // удаление из начала n-элементов
 {
     if (Length > n)
     {
         for (int i = 0; i < n; i++)
         {
             DoubleNode tmp = root.Next;
             tmp.Previous  = null;
             root          = tmp;
             root.Previous = null;
             Length--;
         }
     }
 }
Пример #4
0
        public DoubleLinkedList(int[] a)
        {
            root = new DoubleNode(a[0]);
            DoubleNode tmp = root;

            for (int i = 1; i < a.Length; i++)
            {
                tmp.Next     = new DoubleNode(a[i]);
                tmp.Previous = tmp;
                tmp          = tmp.Next;
            }
            end    = tmp;
            Length = a.Length;
        }
Пример #5
0
 public void DelFromEnd() // удаление из конца одного элемента
 {
     if (root == null)
     {
         root   = new DoubleNode(0);
         end    = root;
         Length = 1;
     }
     else
     {
         end      = end.Previous;
         end.Next = null;
         Length--;
     }
 }
Пример #6
0
        public int SearchMaxElem()// поиск максималного значения
        {
            DoubleNode tmp = root;
            int        max = root.Value;

            for (int i = 0; i < Length; i++)
            {
                if (max < tmp.Value)
                {
                    max = tmp.Value;
                }
                tmp = tmp.Next;
            }
            return(max);
        }
Пример #7
0
        public int SearchMinElem() // поиск минимального значения
        {
            DoubleNode tmp = root;
            int        min = root.Value;

            for (int i = 0; i < Length; i++)
            {
                if (min > tmp.Value)
                {
                    min = tmp.Value;
                }
                tmp = tmp.Next;
            }
            return(min);
        }
Пример #8
0
 public void DelFromBegin() //удаление из начала одного элемента
 {
     if (root != null && root.Next == null)
     {
         root   = new DoubleNode(0);
         Length = 1;
     }
     else
     {
         DoubleNode tmp = root.Next;
         tmp.Previous  = null;
         root          = tmp;
         root.Previous = null;
         Length--;
     }
 }
Пример #9
0
 public void AddFirst(int a)// добавление значения в начало
 {
     if (Length == 0)
     {
         root   = new DoubleNode(a);
         end    = root;
         Length = 1;
     }
     else
     {
         root.Previous      = new DoubleNode(a);
         root.Previous.Next = root;
         root = root.Previous;
         Length++;
     }
 }
Пример #10
0
 public int[] ReturnArray()//возврат массива
 {
     int[] array = new int[Length];
     if (Length != 0)
     {
         int        i   = 0;
         DoubleNode tmp = root;
         do
         {
             array[i] = tmp.Value;
             i++;
             tmp = tmp.Next;
         } while (tmp != null);
     }
     return(array);
 }
Пример #11
0
        public void Add(int a) // добавление значения в конец списка
        {
            if (root == null)
            {
                root   = new DoubleNode(a);
                end    = root;
                Length = 1;
            }

            else
            {
                end.Next          = new DoubleNode(a);
                end.Next.Previous = end;
                end = end.Next;
                Length++;
            }
        }
Пример #12
0
        public int SearchIndexMinElem()//поиск индекса минимального значения
        {
            int        i_min = 0;
            DoubleNode tmp   = root;
            int        min   = root.Value;

            for (int i = 0; i < Length; i++)
            {
                if (min > tmp.Value)
                {
                    min = tmp.Value;
                    i_min++;
                }
                tmp = tmp.Next;
            }
            return(i_min);
        }
Пример #13
0
        public int SearchIndexMaxElem()//поиск индекса мах значения
        {
            int        i_max = 0;
            DoubleNode tmp   = root;
            int        max   = root.Value;

            for (int i = 0; i < Length; i++)
            {
                if (max < tmp.Value)
                {
                    max = tmp.Value;
                    i_max++;
                }
                tmp = tmp.Next;
            }
            return(i_max);
        }
Пример #14
0
 public void AddIndex(int a, int[] b)//добавление массива по индексу
 {
     if (root != null && end != null)
     {
         if (a < Length / 2)
         {
             DoubleNode tmp = root;
             for (int i = 0; i < a - 1; i++)
             {
                 tmp = tmp.Next;
             }
             for (int j = 0; j < b.Length; j++)
             {
                 DoubleNode q = tmp.Next;
                 q.Previous        = tmp;
                 tmp.Next          = new DoubleNode(b[j]);
                 tmp.Next.Previous = tmp;
                 tmp        = tmp.Next;
                 tmp.Next   = q;
                 q.Previous = tmp;
             }
             Length += b.Length;
         }
         else
         {
             DoubleNode tmp = end;
             for (int i = Length; i > a + 1; i--)
             {
                 tmp = tmp.Previous;
             }
             for (int j = 0; j < b.Length; j++)
             {
                 DoubleNode q = tmp.Previous;
                 q.Next                = tmp;
                 tmp.Previous          = new DoubleNode(b[j]);
                 tmp.Previous.Next     = tmp;
                 tmp.Previous.Previous = q;
                 q.Next                = tmp.Previous;
             }
             Length += b.Length;
         }
     }
 }
Пример #15
0
        public int AccessByValue(int a)// вывод индекса по значению
        {
            int        index = 0;
            DoubleNode tmp   = root;

            while (tmp != null)
            {
                if (tmp.Value == a)
                {
                    return(index);
                }
                else
                {
                    tmp = tmp.Next;
                    index++;
                }
            }
            return(-1);
        }
Пример #16
0
 public void DelByIndexNElem(int a, int n)
 {
     if (root != null && end != null)
     {
         if (a < Length / 2)
         {
             DoubleNode tmp = root;
             for (int i = 1; i < a; i++)
             {
                 tmp = tmp.Next;
             }
             for (int j = 0; j < n; j++)
             {
                 DoubleNode q = tmp.Next.Next;
                 q.Previous.Previous = tmp;
                 q.Previous          = null;
                 tmp.Next            = null;
                 tmp.Next            = q;
                 Length--;
             }
         }
         else
         {
             DoubleNode tmp = end;
             for (int i = Length - 1; i > a + 1; i--)
             {
                 tmp = tmp.Previous;
             }
             for (int j = 0; j < n; j++)
             {
                 DoubleNode q = tmp.Previous.Previous;
                 q.Next.Next  = tmp;
                 q.Next       = null;
                 tmp.Previous = null;
                 q.Next       = tmp;
                 Length--;
             }
         }
     }
 }
Пример #17
0
        public void RevMassive()// ревес массива
        {
            if (root != null && end != null)
            {
                DoubleNode tmp = root;
                tmp.Previous = tmp.Next;
                tmp.Next     = null;
                tmp          = tmp.Previous;

                while (root.Previous != null)
                {
                    tmp.Previous = tmp.Next;
                    tmp.Next     = root;
                    root         = tmp;
                    tmp          = tmp.Previous;
                }
                while (end.Next != null)
                {
                    end = end.Next;
                }
            }
        }
Пример #18
0
        public int ReturnLengthMassiva()//возврат длины массива
        {
            DoubleNode tmp     = root;
            int        ilength = 1;

            if (tmp == null)
            {
                ilength = 0;
            }
            else if (tmp != null && tmp.Next == null)
            {
                ilength = 1;
            }
            else if (tmp != null && tmp.Next != null)
            {
                while (tmp.Next != null)
                {
                    tmp = tmp.Next;
                    ilength++;
                }
            }
            return(ilength);
        }
Пример #19
0
 public void AddIndex(int a, int b) // добавление значения по индексу
 {
     if (root != null && end != null)
     {
         if (a < Length / 2)
         {
             DoubleNode tmp = root;
             for (int i = 0; i < a - 1; i++)
             {
                 tmp = tmp.Next;
             }
             DoubleNode q = tmp.Next;
             q.Previous        = tmp;
             tmp.Next          = new DoubleNode(b);
             tmp.Next.Previous = tmp;
             tmp.Next.Next     = q;
             q.Previous        = tmp.Next;
             Length++;
         }
         else
         {
             DoubleNode tmp = end;
             for (int i = Length; i > a + 1; i--)
             {
                 tmp = tmp.Previous;
             }
             DoubleNode q = tmp.Previous;
             q.Next                = tmp;
             tmp.Previous          = new DoubleNode(b);
             tmp.Previous.Next     = tmp;
             tmp.Previous.Previous = q;
             q.Next                = tmp.Previous;
             Length++;
         }
     }
 }
Пример #20
0
 public void AddFirst(int[] a)// добавление массива в начало
 {
     if (root == null)
     {
         root = new DoubleNode(a[Length - 1]);
         for (int i = a.Length - 2; i >= 0; i--)
         {
             root.Previous      = new DoubleNode(a[i]);
             root.Previous.Next = root;
             root = root.Previous;
         }
         Length = a.Length;;
     }
     else
     {
         for (int i = a.Length - 1; i >= 0; i--)
         {
             root.Previous      = new DoubleNode(a[i]);
             root.Previous.Next = root;
             root = root.Previous;
         }
         Length += a.Length;;
     }
 }
Пример #21
0
 public void ChangesByIndex(int a, int b) // изменения по индексу
 {
     if (root != null && end != null)
     {
         if (a < Length / 2)
         {
             DoubleNode tmp = root;
             for (int i = 0; i < a; i++)
             {
                 tmp = tmp.Next;
             }
             tmp.Value = b;
         }
         else
         {
             DoubleNode tmp = end;
             for (int i = Length - 1; i > a; i--)
             {
                 tmp = tmp.Previous;
             }
             tmp.Value = b;
         }
     }
 }
Пример #22
0
 public DoubleNode(int value)
 {
     Value    = value;
     Previous = null;
     Next     = null;
 }
Пример #23
0
 public void SortDescending()
 {
     if (root != null && end != null)
     {
         if (root != null && root.Next == end)
         {
             DoubleNode tmpRoot = root;
             DoubleNode tmpEnd  = end;
             if (root.Value < end.Value)
             {
                 tmpRoot.Next     = null;
                 tmpRoot.Previous = tmpEnd;
                 tmpEnd.Previous  = null;
                 tmpEnd.Next      = tmpRoot;
                 root             = tmpEnd;
                 end = tmpRoot;
             }
             else
             {
                 root = tmpRoot;
                 end  = tmpEnd;
             }
         }
         else
         {
             for (int i = Length - 1; i > 0; i--)
             {
                 DoubleNode tmpRoot = root;
                 DoubleNode tmp     = root.Next;
                 if (tmpRoot.Value < tmp.Value)
                 {
                     tmpRoot.Next     = tmpRoot.Next.Next;
                     tmp.Next         = tmpRoot;
                     tmpRoot.Previous = tmp;
                     tmp.Previous     = null;
                     root             = tmp;
                 }
                 else
                 {
                     while (tmp.Next != null)
                     {
                         if (tmp.Value > tmp.Next.Value)
                         {
                             DoubleNode q = tmp.Next;
                             DoubleNode b = tmp.Previous;
                             tmp.Next          = tmp.Next.Next;
                             tmp.Previous.Next = q;
                             q.Previous        = tmp.Previous;
                             q.Next            = tmp;
                             tmp.Previous      = q;
                         }
                         else
                         {
                             tmp = tmp.Next;
                         }
                     }
                 }
             }
         }
     }
 }
Пример #24
0
 public DoubleLinkedList()
 {
     root   = null;
     end    = null;
     Length = 0;
 }
Пример #25
0
 public DoubleLinkedList(int a)
 {
     root   = new DoubleNode(a);
     end    = root;
     Length = 1;
 }