Example #1
0
 public void Insert(int index, Pupil pupil)
 {
     if (_pupils.Length == 0)//0er-Array
     {
         _pupils             = new Pupil[_nextIndex + 1];
         _pupils[_nextIndex] = pupil;
     }
     else if (_pupils[_pupils.Length - 1] == null)//Leeres Ende
     {
         for (int i = _pupils.Length - 1; i > index; i--)
         {
             if (_pupils[i] != null)
             {
                 _pupils[i + 1] = _pupils[i];
             }
         }
         _pupils[index] = pupil;
     }
     else//Volles Ende 1,2
     {
         int     i = 0;
         bool    wasNotInMiddle = true;
         Pupil[] temp           = new Pupil[_pupils.Length + 1];
         while (i < _pupils.Length)
         {
             temp[i] = _pupils[i];
             if (i == index)
             {
                 temp[i]     = pupil;
                 temp[i + 1] = _pupils[i];
                 i++;
                 wasNotInMiddle = false;
                 continue;
             }
             i++;
         }
         if (wasNotInMiddle)
         {
             temp[i] = pupil;
         }
         _pupils = temp;
     }
     _nextIndex++;
 }
Example #2
0
        public void Sort()
        {
            int   length = _pupils.Length;
            Pupil temp   = _pupils[0];

            for (int i = 0; i < length; i++)
            {
                for (int j = i + 1; j < length; j++)
                {
                    if (_pupils[i].Age > _pupils[j].Age)
                    {
                        temp = _pupils[i];

                        _pupils[i] = _pupils[j];

                        _pupils[j] = temp;
                    }
                }
            }
        }
Example #3
0
 public void Add(Pupil pupil)
 {
     Insert(_nextIndex, pupil);
 }