5 способов побольше узнать об алгоритмах

От Википедии до курсов ШАДа и MIT

5 способов побольше узнать об алгоритмах

Разработка

Подавляющее большинство кандидатов на позицию разработчика в Яндексе проходят проверку на знание алгоритмов. Если вы присматриваетесь к вакансиям или просто хотите развить свои навыки, посмотрите нашу подборку материалов по алгоритмам и структурам данных.

Лекции «Алгоритмы и структуры данных» в Школе анализа данных

Цикл лекций, который ежегодно читает Максим Бабенко — заместитель директора отделения компьютерных наук ШАДа, кандидат физико-математических наук, доцент кафедры алгоритмов и технологий программирования МФТИ и заведующий базовой кафедрой ФКН НИУ ВШЭ. В своём курсе Максим рассматривает базовые алгоритмы и структуры, сложность и модели вычислений, деревья поиска, B-деревья, задачи геометрического поиска, динамическую связность в графах и другие темы.

Курс Introduction to Algorithms Массачусетского технологического университета (MIT)

Классика, которая совершенно не устаревает, а, наоборот, становится более актуальной в наши дни, когда алгоритмы закрепились даже в профессии фронтенд-разработчика (не говоря уже о других специальностях). Преподаватели MIT отвечают на все каверзные вопросы об алгоритмах, начиная с самого лёгкого — зачем их изучать. Это не просто набор теоретических рассмотрений, это последовательное руководство, которое буквально поменяет вашу модель мышления. Вы научитесь действовать алгоритмически при решении многих задач и станете гораздо интереснее для любого работодателя.

Специализация «Структуры и алгоритмы данных» на Coursera

Здесь вам предлагается самостоятельно выполнить больше ста заданий и таким образом детально познакомиться с алгоритмами. Вы сами набьёте все шишки, связанные с изучением алгоритмов, а затем перейдёте к проектам на основе данных из реального мира. Знать классические алгоритмы нужно, но вы увидите, что некоторые современные подходы работают гораздо быстрее. Эту специализацию подготовили сотрудники Калифорнийского университета в Сан-Диего и факультета компьютерных наук Вышки.

Списки алгоритмов и структур данных на Википедии

 Не игнорируйте Википедию (здесь можно посмотреть список алгоритмов, здесь структур данных). В данном случае она служит не только источником самых базовых знаний, но и справочником, к которому полезно возвращаться время от времени. Изучив алгоритм, посмотрите, какие у него есть аналоги, в чём состоят смежные идеи.

Алгоритмические задания на HackerRank

Среди всех ресурсов с задачами для программистов HackerRank выделяется двумя вещами. Во-первых, на этой платформе зарегистрированы реальные компании с актуальными задачами и данными из продакшна. Здесь можно не просто уловить направления, на которые сейчас обращают внимание команды при найме, но и детально узнать, чего именно они ждут от кандидатов. Во-вторых, HackerRank позволяет уделить много времени именно алгоритмическим задачам, если вы этого хотите.

Больше по теме

Разработка

Основные виды сортировок и примеры их реализации

Памятка для тех, кто готовится к собеседованию на позицию разработчика

Разработка

Python: простые, но полезные советы по оптимизации кода

Санитарная обработка данных, пропуск начала итерируемого объекта и другие приёмы

Разработка

Как проходит проектная часть Школы разработки интерфейсов?

История команды, которая разработала личный кабинет для кандидата на обучение в Школе

Анализ данных, Разработка

Чем занимается разработчик инфраструктуры и как им стать

«Для нас все остальные разработчики Яндекса — пользователи»

Разработка

Язык программирования Rust: видеозаписи лекций курса от CS центра

Освойте безопасный язык программирования для браузеров

Разработка

Спорт для разработчиков: как устроено олимпиадное программирование

Ключевые соревнования, советы по подготовке и работе в команде

Разработка

Подборка игр и тренажёров для начинающих разработчиков интерфейсов

Освойте базовый синтаксис HTML и CSS, технику Pixel Perfect и красивую вёрстку