Курсы по программированию

Формула программиста
основатель — Волосатов Евгений Витольдович

Коллекция графов / Array vs List

  • На этом уроке мы сравним эффективность использования
    ArrayList, List<> и простого массива.
    Победителем окажется типизированная коллекция List<>.
    Очень интеренсо сравнивать эффективность,
    нам в этом поможет флагманский класс Stopwatch.
  • Дата отправки отчёта: 15 апреля
  • Задание выполнено: за 20 мин.
  • Чему научился: повторил использование stopwatch.
  • Что было сложным: Все хорошо.
  • Комментарии: жду продолжения. Очень интересно!
  • Оценка видео-уроку:
Отчёт от 2146 за Коллекция графов / Array vs List




Оцени работу

 
Сохранить страницу:

  • Отчёт оценивали:
    2146Иван+1   1Евгений Витольдович+1   4467Alcatraz+1   3506Алексей|BrisK|Кривицкий+1   6452Lik_Kirill+1   9263Андрей Н.+1   4992Николай+1   6644valerys Nikola+1   1901Neverwinter 2+1   6925Артём+1   1537Сергей+1   9237Mais+1   9567Максим+1   8886Михаил Ермишин+1   689Igorenzia+1   7645Александр Львович+1   459Сергей Сергеевич+1   429Максим Базуев+1   1967Дмитрий+1   7652Петя+1  

Начинаем практику по языку C#




Чтобы стать хорошим программистом — нужно писать программы. На нашем сайте очень много практических упражнений.

После заполнения формы ты будешь подписан на рассылку «C# Вебинары и Видеоуроки», у тебя появится доступ к видеоурокам и консольным задачам.

Несколько раз в неделю тебе будут приходить письма — приглашения на вебинары, информация об акциях и скидках, полезная информация по C#.

Ты в любой момент сможешь отписаться от рассылки.
Научился: сравнивать время выполнения функций
Трудности: особо ничего
если сделать просто массив Program[] он также будет быстрее List
Научился: Сoздaл три отдeльныe фyнкции List0(), List1(), List2(), которые реализуют соответственно базовый массив, ArrayList и типизированный список List.
Трудности: Ничего.
В своем случае я я выбрал такой набор операций: for (int i = 0; i < length; i++) al.Add(length - i); В общем случаем я заполняю массив / коллекцию по спадению от 1 000 000 до 1. Потом вызываю метод сортировки Sort() или Array.Sort(T[] array), который работает с худшим вариантом для сортировки, потому, что ему нужно полностью переставить все элементы в обратном порядке. И измеряю время которое затрачивается на это. Результаты показывают, что на сортировку типизированного списка List затрачивается не много больше времени, чем для обычного массива (и учтите, что при добавлении элементов в список он часто увеличивал свою емкость). А коллекция ArrayList ужасно проигрывает по времени всем. Результаты представлены на 1 скриншоте. Во 2м случае тестировки я немного выровнял шансы и указывал при инициализации коллекций емкость в 1 000 000 элементов. Результаты тестировки представлены на 2м скриншоте.