С наступающим, Хабр.
Новый год – точка, после которой все мы собираемся что-то начать, чем-то заняться, в чём-то поднатореть. Сегодня я расскажу об одном из таких вариантов – что можно начать и как к этому подойти.
Конечно, про литкод все слышали и, казалось бы, о чём тут рассказывать? Ну задачник, ну перед техсобесами можно открыть на день-два. Но для того рассказать и стоит, дабы чуть разбавить это мнение.
С сайтом несколько больно знакомиться, он отпугивает вездесущими приписками «premium», пользуясь славой ресурса для техсобесов продвигает функционал вроде списков компаний, где встречался вопрос n и симуляции интервью в компанию m, да и сам не особо стремится рассказать о себе, потому в нём зачастую и видно голый задачник с одной страницей «problems».
За всем этим теряется важный пункт – а можно ли использовать сайт не для механического зазубривания популярных вопрос-ответов, а для изучения/закрепления алгоритмов и структур данных? Можно. Но подход к этому нужно формировать самостоятельно.
Тему «а кому вообще нужны алгоритмы» и её более радикальную вариацию мы затрагивать не будем, в этой священной войне уже немало копий сломано. Если вы открыли этот пост, как минимум вы допускаете, что кому-то да нужны.
На сайте присутствует платная подписка, которая закрывает часть контента. Не считая влияния на UI, это не критично, бесплатной части нам хватит, к тому же подписку можно получить и бесплатным способом, о чём мы также поговорим. Но, чтобы каждый раз не уточнять, какая часть подписочная, а какая общая – платный функционал я буду помечать [квадратными скобками].
Материал предполагается как точка входа для незнакомых с сайтом, а описание разделов содержит детали, которые не упомянуты даже в официальном faq, хотя должны бы.
Но сначала несколько общих фраз.
Что вообще может дать литкод?
-
Знание алгоритмов и структур данных – 7/10
-
И о задачах мы тут говорим только во вторую очередь. Задачи – инструмент закрепления знаний, но для этого их нужно получить, и, крайне желательно, структурировано. На сайте есть специальные разделы посвящённые этому. Не полные, но в качестве вводной в определённую тему вполне подойдут. Дальнейшее ознакомление с теорией остаётся в качестве домашней работы.
-
Отдельно стоит отметить сообщения в разделе обсуждений к задачам, которые некоторыми пользователями пишутся с размахом небольшого гайда по конкретной теме. Также бывают весьма полезны, с учётом того, что эти сообщения пропущены пользователями «через себя» – как они пришли к пониманию темы.
-
-
Понимание применимости алгоритмов на практике – 10/10
-
Основное преимущество литкода не в том, чтобы предложить вам побольше сферических задач в вакууме, а именно, чтобы показать, как ваши новые знания могут быть применены к самым разным задачам, которые до этого вы, возможно, стали бы решать в лоб, и насколько это было бы хуже. В официальных решениях зачастую ответы так наглядно и идут – от самого простого, но неэффективного, к наиболее правильному, но не самому очевидному решению.
-
Один из примеров – тема бинарного поиска. Сначала сайт знакомит с базовым представлением – вот отсортированный массив, вот target, вперёд. Потом вам предлагают сделать то же с матрицей, с повёрнутым массивом, и с прочими усложнёнными вариациями. А потом из входных данных пропадает и массив для ожидаемого поиска, и target, в виде простого значения из него. Теперь вы сами формируете и последовательность, и условие поиска, отталкиваясь от прочих входных данных, для задачи, которая, на первый взгляд, никак к изучаемой теме не относилась. Такие моменты, когда вы открываете новые подходы, неважно какого уровня сложности, всегда приятные.
-
-
Оценка входных данных, тесткейсов, сложности задачи и собственных сил – 7/10
-
Правильно определить границы работы кода и продумать краевые случаи – обязательный пункт любого решения. Причём если последние зачастую исправляются парой дополнительных условий с досрочным выходом, то первые могут повлиять на весь подход к решению.
-
Литкод также неплохо помогает бороться с крайностями «я всё/ничего не знаю», что никогда не бывает лишним. Досада от не найденного или явно плохого решения будет иногда возникать, но это неотъемлемая часть обучения. Зато к таким задачам приятно возвращаться снова, чувствуя разницу в силах.
-
-
Навык чтения и оценки кода – 5/10
-
«Код пишется один раз, а читается сотни». И данный ресурс не исключение. Вам, помимо собственных прошлых решений, так или иначе придётся часто обращаться к чужим решениям – для сверки решения, подсказки, поиска альтернативных подходов. А там вы обнаружите самый разнообразный код – на разных языках, в разных стилях, с устаревшими и только набирающими популярность подходами, и, конечно, от пользователей с разным уровнем подготовки. Вы привыкнете быстро оценивать качество как самого кода, так и подхода к решению, подмечать фрагменты, которые можно оптимизировать, и станете больше ценить читаемость в собственных решениях.
-
-
Английский и прочие смежные темы – 2/10
-
Всё что выше и ниже – не на великом и могучем, а на английском, ближе к «техническому». Неплохая подспудная практика. Что же касаемо прочих тем – тут стоит выделить задачи с тегами Database и Math. Первые – задачи на SQL, и left join’ами они не ограничиваются. Задачи из второго тега обычно отсылают к соответствующим знаниям, но куда интереснее задачи, в которых прямое решение, растягивающееся на 50+ строк, доказывается математически и сворачивается до пары-тройки выражений. Литкод также пытался и в другие темы, вроде shell’a, и хоть пока там всего 4 задачи, но намётки есть.
-
-
Знание стандартной библиотеки и синтаксических хитростей – 2/10
-
При решении алгоритмических задач вы с куда большей вероятностью столкнётесь с теми особенностями вашего ЯП, которые обычно упускаются при решении задач другого толка.
-
-
Преимущество при трудоустройстве – 1/10 и 10/10
-
Для первых этапов ссылка на литкод едва ли будет чем-то большим, чем незначительное конкурентное преимущество. Можно порассуждать, как литкод-профиль демонстрирует ваше стремление к развитию, непосредственно саму алгоритмическую подготовку и прочее… Но вы либо подходите по требованиям вакансии, либо нет, и обсуждаемая тема в этих требованиях встречается ой как редко.
-
Ну а про алгоритмическую секцию комментарии излишни – решайте задачи, и все вопросы ваши, особенно с учётом того, что нередко их с литкода-то и берут (или же они впоследствии на него попадают). Обилие историй успеха по одноимённому запросу это только подтверждает.
-
Также литкод дополнительно ведёт статистику самых популярных вопросов на собеседованиях [и любимых вопросов в FAANG’е, и вы можете подготовиться даже к собеседованию в выбранную компанию].
-
Но пора бы уже перейти и к наполнению сайта.
В общем о задачах
Задачи составляют основу сайта и могут быть доступны из разных разделов. На сегодняшний день доступно 2000 [+530] задач, в их числе 45 [+175] для SQL и по 5 на shell и concurrency. Для алгоритмических задач, для решения предлагается
Тот самый раздел, который обычно и ассоциируется с сайтом. Давайте поскорее от него отойдём. Из востребованного кликабельного: тут есть фильтры по тегам, статусу и сложности; сортировка по проценту принятия (количество принятых решений ÷ количество отправленных решений). Комбинацией этих фильтров можно подбирать задачи по уровню и интересу. Если задача решается в прочих разделах, она помечается решённой и в общем списке. Но не наоборот. Собственно, и всё. Двигаемся дальше. Относительно новый функционал. Добавился чуть более года назад, и с тех пор регулярно дополняется. Планы – это структурированные наборы задач по выбранной теме, в конкретном порядке, рассчитанные на определённое количество дней. На сегодняшний день доступно
Раздел, который благодаря восхитительному дизайну выглядит как очередная реклама подписки, но это не так. Учебник разделён на две области – подготовка к тех.собеседованиям и изучение самих тем АиСД. На главной представлены по [8] тем из каждой области[[, первые из которых дополнительно платные сверх подписки, господи]]. Интересное же завёрнуто под «more» каждой области. Там мы найдём 8 полностью бесплатных тем и 13 с незначительными ограничениями. Рекомендую сразу прокликать их в избранное для быстрого доступа. Learn The LeetCode Beginner’s Guide – free Arrays 101 – 30/31 Sorting – free Linked List – 26/30 Binary Tree – 16/19 Recursion I – 20/21 Recursion II – 23/25 Machine Learning 101 – free Binary Search – 28/30 N-ary Tree – 6/11 Binary Search Tree – 15/21 Trie – 11/14 Hash Table – 30/35 Array and String – free Queue & Stack – 30/32 Decision Tree – free Interview Rock the Behavioral Interview – текст Coding Interview Strategy – текст Top Interview Questions (easy) – задачник Top Interview Questions (medium) – задачник – 46/52 Top Interview Questions (hard) – задачник – 48/51 Темы разделены на главы, состоят из страниц и задач, страницы содержат текст, видео и тесты, тут ничего необычного. Темы раздела собеседований бросаются из крайности в крайность – где-то вода, где-то голые списки задач. А вот раздел Learn весьма полезен. Суммарно в разделе Learn вам предложат 190 задач (без учёта повторений) и 180 в Interview. Как и планы – учебник хорош именно своей структурой, но в дополнение к ней также имеет и теоретическую часть, что делает его основным разделом сайта на первое время. Неплохим закрепляющим вариантом будет параллельное прохождение одних и тех же тем в планах и учебнике, хотя это будет довольно однообразно. Чтобы избежать повторения вопросов, которое обязательно случится в таком подходе, план можно запускать чуть заранее, открывая часть вопросов, чтобы они закрывались при решении из учебника. Логический предшественник планов и учебника. Списки задач, из имеющихся на сайте, могут быть составлены любым участником для собственных нужд или для публикации по ссылке. В разделе «problems» литкод предлагает 8 собственных списков, но это просто «топы»: 100 самых рейтинговых вопросов, 150 самых частых вопросов на интервью, топ вопросов в компанию n. Пройтись по ним перед собеседованием можно, но в них нет ни структуры, позволяющей использовать их для определения общего порядка решения, ни игрового стимула, даже отметки выполнения нет. К тому же, из 8 существующих официальных списков – 6 в квадратных скобках, один в полуквадратных, и только «Top 100 Liked Questions» может быть выполнен полностью. Раздел, на котором вы можете запустить симуляцию технического собеседования с 2, 3 или 4 вопросами, в любом варианте – по 30 минут на каждый вопрос. Вопросы случайно выбираются из списков – общего [и по конкретной компании]. При прохождении вопросов вы не видите их названия и номера, а также в тестах не отображается ожидаемый вывод. По завершении симуляции (полное решение, истечение времени, досрочный выход) сайт предоставит оценку вашего решения данного набора задач. Решённые задачи также отметятся в общем списке задач. Требует уточнения, но, кажется, задачи для симуляции подбираются из числа нерешённых ранее. После нескольких симуляций появится доступная только вам оценка навыков по 8 темам – массивы и строки, деревья и графы, рекурсия, …. Раздел с сомнительной полезностью, разве что для интереса раз в полгода можно и пройти. Каждое воскресенье в 5:30 утра по МСК (так уж получилось) и каждую вторую субботу в 17:30 (в дополнение к воскресному) начинается турнир с 4 задачами на полтора часа. Соотношение условной сложности привычное – 1e/2m/1h. Задачи всегда новые, ни готовых решений в интернете, ни вкладки обсуждения нет. Каждая задача оценивается в некоторое количество баллов, обычно 3/4/5/6, 3/4/4/6 или 3/5/5/6. Есть особенности и со стороны проверки решения: некоторые тесты при срабатывании скрывают, какой ответ ожидается или на каких входных данных произошло срабатывание, что может сильно помешать в отлове ошибки так как вопросы новые, тесты для проверки могут быть дополнены после турнира, и если вы понимаете, что ваше, даже принятое, решение моментами захардкожено или пропускает какие-либо частные случаи, стоит по возможности его доработать. Иначе на дополненных тестах оно рискует не пройти, и ваши баллы и позиция будут пересчитаны. Данная ситуация совсем не редкая, как может показаться. Для формирования таблицы результатов используется сумма баллов за решённые задачи, вспомогательная сортировка происходит по времени затраченному на решения (по времени последнего правильного решения). Также ко времени добавляется по 5 «штрафных» минут за каждое отправленное неправильное решение (только для решённых задач). Не стоит недооценивать штрафное время, оно может существенно повлиять на вашу итоговую позицию. В зависимости от занятого места меняется ваш общий турнирный рейтинг. Так как вопросы, даже при условном делении на e/m/h, из турнира в турнир будут отличаться по сложности, может сложиться так, что 4/4 решённых задач в лёгком турнире, где все выступили хорошо, дадут меньшую прибавку к рейтингу, чем 2/4 в сложном, ведь влияет ваша позиция относительно других участников. Прибавка к рейтингу конечно зависит и от ваших прошлых результатов. Подробнее о подсчёте рейтинга с формулами можно почитать здесь. Для участия необходимо зарегистрироваться на странице конкретного турнира, по желанию заполнив анкету или нажав в «continue to register». Сделать это можно хоть за неделю до начала, хоть за минуту, а можно присоединиться и к уже начавшемуся турниру, но время окончания у вас будет общее со всеми. Если вы зарегистрируетесь на турнир, но пропустите его (с учётом времени, скорее – проспите), ваш рейтинг всё равно снизится, потому будьте осторожны с предварительной регистрацией. Отменить регистрацию на турнир можно, но куда надёжнее регистрироваться перед самым стартом. По завершению турнира вопросы отправляются в общий список, по ним открываются обсуждения, формируется предварительная таблица результатов турнира. Решённые вами на турнире вопросы в общем списке также отмечаются решёнными. Примерно в пятницу (+/- 1 день) результаты прошлой недели пересчитываются и закрепляются, участникам обновляют рейтинг. До пятницы дорабатываются тесты к вопросам, выявляются нечестные участники, рассматриваются жалобы на нечестную игру от пользователей. Участникам, с общим турнирным рейтингом входящим в 25% лучших, из числа всех участников с рейтингом 1600+, выдаётся бейджик «knight». На текущий момент это участники с рейтингом 1850+ (5.3% от всех участников). Для 5% «лучших из лучших» этот бейджик заменяется на «guardian», он на текущий момент требует 2175+ рейтинга (1.1% от общего). Если рейтинг понижается ниже требуемого, будь то неудачным выступлением, или общим повышением уровня, «guardian» обратно заменяется на «knight», а в случае последнего – сереет. Периодически поднимается тема турнирных сезонов (1-2 в год), но пока рейтинг не привязан ко времени, и на ближайшее время подобные изменения не заявлялись. Некоторые турниры спонсируются определёнными компаниями. Для участников, кроме призёров, это ничего не значит – турниры не меняют ни времени, ни правил. Внеплановых турниров, пока, тоже нет. Вы можете попробовать свои силы и без влияния на рейтинг, в удобное для вас время – на странице турниров просто начинаете virtual contest по интересующему турниру и по тем же правилам проходите его. Хороший вариант опробовать, не пора ли вам принимать участие в них. Решённые в рамках виртуального участия вопросы также учитываются в общий список. Игрофикация прохождения с подкреплением наградами в профиле. В рамках месячных соревнований всем пользователям предлагается одна задача в день [и, дополнительно, одна в неделю] из общего списка. Задачи на каждый месяц выбираются администрацией сайта и каждые несколько дней держат одну тему. Сложность, обычно, нарастает к концу месяца, и к концу темы. Решившим все ежедневные задачи месяца выдаётся соответствующий бейджик, как в общий список наград пользователя, так и в отображении статистики года. Пропущенные дни можно закрыть задним числом за местную игровую валюту, но закрывать можно только пропуски текущего календарного года и только три раза в календарный месяц. Теоретически, если начать в марте, не пропуская ни дня, к концу года на излишки можно закрыть февраль в прошлом, но большого смысла в этом нет. Пройденные ежедневные задачи без пропусков
Обращайте внимание на follow-up приписки. Тесты пропускают решения не соответствующие им, и эта часть остаётся на ваше усмотрение, но стоит подумать о том, как можно улучшить ваше решение. Аналогично, нередко задачи лёгкого уровня допускают грубые решения, попросту ограничивая входные данные. Попробуйте решить задачу правильно, как если бы на вход могли поступать и бо́льшие значения. Некоторые задачи могут решаться в одну строку, с использованием пары встроенных функций языка. Если вы понимаете, что это не то, что от вас требуется – для себя, решите их так, как предполагается в рамках изучаемой темы. После решения задачи подумайте, как ещё можно было подойти к решению. Сверьтесь с решениями литкода или других пользователей в обсуждениях. Возьмите за правило перед отправкой решения тратить минуту, чтобы перечитать условие и подумать о частных случаях. Это нередко будет экономить вам по 5 потенциальных штрафных минут для таблицы результатов. Если нет возможности/желания участвовать во всех турнирах, старайтесь принимать участие на неделях с двойными турнирами. Это даст достаточный турнирный прогресс и монеты, при участии всего раз в две недели. На турнирах можно обращаться к общему списку задач – если возникли сложности, постарайтесь припомнить схожую задачу, её решение может помочь вам. На странице любой задачи нажмите в подсказку возле выбранного вами ЯП, ознакомьтесь, какие возможности доступны, помимо «из коробки». Посмотрите аддоны по запросу «leetcode» для вашего браузера. Таймеры, скрытие [вопросов], счётчики сложности для листов, локальные заметки к задачам, дополнительные видео-решения, форматтеры, etc. Иногда заглядывайте во вкладку обсуждений официального профиля LeetCode. Там публикуются обновления, новые планы и карточки учебника. Они некоторое время отображаются на главной странице, но в профиле следить за единым списком удобнее. Если вы понимаете, что можете оставить некоторое количество задач в плане на последний день, перед запуском уровня обратите внимание, в какой день недели он заканчивается, подгадайте свободный. Не участвуйте с телефона, особенно в турнирах. Очевидные неудобства озвучивать не буду, но отмечу, что можно поймать мультиязычность и расширенный символьный ввод на любой раскладке. Вдруг кому интересно. Увидимся в следующем году!Что есть на сайте
Problems / общий список
Study plan
Explore
Открытые темы:
Lists
Assessment
Contest
Месячные и годовые соревнования
Задания с опциональной сложностью
Турниры
Прочее
ссылка на оригинал статьи https://habr.com/ru/post/708570/
Добавить комментарий