Skip to content

Latest commit

 

History

History
2024 lines (1698 loc) · 168 KB

File metadata and controls

2024 lines (1698 loc) · 168 KB

Google Interview University

Оригинальная версия: Английский

Для кого это?

Это мой учебный план рассчитанный на несколько месяцев для веб-разработчиков, не имеющих образования в Computer Science (CS) и планирующих работать инженерами-программистами (software engineer) в компании Google.

Кодирование на доске - из телесериала канала HBO Кремниевая Долина

За основу учебного плана я взял список вопросов Google's coaching notes и значительно расширил его. Тут вы найдёте много полезных вещей, которые необходимо знать. Дополнительные вопросы я добавил в конец списка, их могут задавать на интервью, так же они могут быть полезны в решении повседневных задач. Некоторые пункты я взял из поста Стива Йеги (Steve Yegge) "Получить работу в Google", а некоторые слово в слово соответствуют вопросам, разбираемых Google в их постах о подготовке.

Я сократил тот объем знаний, который необходим, по сравнению с рекомендациями Йеги. Я изменил требования Йеги исходя из той информации, которую мне предоставил мой знакомый из Google. Это важно для тех, кто сейчас еще новички в разработке программного обеспечения или являются веб-разработчиками и планируют стать инженерами-программистами (это та профессия где требуются знания в области CS). Если вы опытный разработчик, ожидайте что собеседование будет сложным. Подробнее.

Если вы обладаете многолетним опытом разработки ПО, помните, что Google разделяет понятия инженер-программист и разработчик ПО/веб-разработчик. Первое требует знаний в области CS.

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


Содержание

---------------- Все что ниже - опционально ----------------


Чем это полезно?

Я следую этому плану, готовясь к собеседованию в Google. Я разрабатываю веб-приложения, сервисы и запускаю стартапы с 1997 года. У меня есть степень по экономике, но нет по CS. До сих пор у меня очень успешная карьера, но я хочу работать в Google. Я хочу работать с большими системами и понять принципы их работы, изучить эффективность алгоритмов и различные структуры данных, узнать, как работают низкоуровневые языки программирования. Если ты не знаешь что-то из перечисленного, Google не возьмёт тебя на работу.

Когда я начал этот проект, я ничего не знал о стеке, куче, Big-O, деревья и способах обхода графа. Если бы мне нужно было писать код для сортировки, это было бы не очень хорошо. Структуры данных, которые я использовал, были частью языка, и я не знал, как они на самом деле работали. Мне никогда не приходилось управлять памятью, если процесс, который я запускал, сообщал об ошибке "out of memory", я искал способ как ее обойти. Я использовал в своей работе несколько многомерных массивов и тысячи ассоциативных, но никогда не создавал структуру данных "с нуля".

Но после выполнения этого учебного плана я поверил, что Google меня наймет. Это длинный путь. Я потрачу на это месяцы. Если вы уже знакомы с большинством тем, то потратите намного меньше времени.

Как пользоваться

Ниже описан способ использования, вы должны выпонить пункты в описаном порядке.

Я использую разметку Github, включая список задач для оценки прогресса.

  • Создай новую ветку и тогда вы сможете оставлять отметки у элементов списка, просто добавляя x внутрь скобок: [x]

     Скопируй репозиторий и выполни команды перечисленные ниже
    

git checkout -b progress

git remote add jwasham https://github.com/jwasham/google-interview-university

git fetch --all

Mark all boxes with X after you completed your changes

git add .

git commit -m "Marked x"

git rebase jwasham/master

git push --force

Подробнее о разметке на Github

Получи гугловское настроение

Напечатай знак "future Googler" и не отводи глаз от желанной добычи.

future Googler sign

Получил ли я работу?

Пока я ожидаю своей очереди. Надеюсь интервью будет скоро.

Thanks for the referral, JP.

Двигайся вместе со мной

Моя история: Почему я готовился в течении 8 месяцев для собеседования в Google

Я еще на пути к цели. Двигаемся вперед:

John Washam - Google Interview University

Не переживайте о том, что вы не достаточно умны

О Google

О видео ресурсах

Некоторые видео доступно в том случае, если вы являетесь слушателями курсов Coursera, EdX или Lynda.com Их называют MOOCs. Некоторые курсы не имеют круглогодичного доступа и вам нужно подождать несколько месяцев, прежде чем получите к ним доступ. Курсы на Lynda.com платные.

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

Процесс собеседования & Основное в подготовке к интервью

Выберите один язык для собеседования

Я написал небольшую статью об этом: Важно: Выберите один язык для собеседования в Google

На этапе собеседования, когда требуется программировать, вы можете использовать наиболее комфортный для вас язык программирования. Для Google лучшим выбором будут следующие:

  • C++
  • Java
  • Python

Так же подойдут:

  • JavaScript
  • Ruby

Для вас должно быть комфортно писать программы на выбранном языке и вы должны его хорошо знать.

Подробнее о выборе:

Ресурсы по языкам программирования вы можете найти тут

Вы найдете кое-что по С, С++ и Python ниже, потому-что я еще в процессе обучения.

Список книг

Это краткий список, того чем я пользовался. Он сокращен, для того что-бы сэкономить ваше время.

Подготовка к собеседованию

Если у вас есть много свободного времени:

Архитектура компьютера

Если мало времени:

  • Писать отличный код: Том 1: Понимание компьютера
    • Книга была опубликована в 2004 и отчасти она устарела, но благодаря ей вы быстро поймете как устроены компьютеры.
    • Автор придумал HLA, поэтому скептически отнеситесь к примерам и упоминаниям HLA. Широко не используется, но содержит ряд примеров, демострирующих assembler.
    • Чтение следующих глав не займет много времени и даст хорошую основу:
      • Глава 2 - Представление в числовой форме
      • Глава 3 - Двоичная арифметика и битовые операции
      • Глава 4 - Представление числа с плавующей запятой
      • Глава 5 - Представление символа
      • Глава 6 - Организация памяти и доступа
      • Глава 7 - Составные типы данных и объекты в памяти
      • Глава 9 - Архитектура CPU
      • Глава 10 - Набор инструкций
      • Глава 11 - Архитектура и организация памяти

Если вы рапологаете свободным временем (я хочу купить эту книгу):

По языкам программирования

Вам необходимо выбрать один язык для интервью (смотри выше). Здесь вы найдете мои рекомендации по языкам. У меня нет информации по всем языкам, но если есть у вас - добро пожаловать.

Если вы читали одну из них, то у вас есть достаточно знаний по алгоритмам и структурам данных и вы можете приступить к решению задач по программированию. Вы можете пропустить все видео лекции в этом разделе, если не хотите повторить темы.

Дополнительные ресурсы по языкам программирования здесь

C++

Я не читал обе, но они весьма полезны и написаны Седжвиком (Sedgewick). Он отличный автор.

Если вы можете порекоммендовать литературу по C++, которая лучше, сообщите мне об этом. Я ищу лучшие книги.

Java

или:

  • Структуры данных и алгоритмы на Java
    • авторы Goodrich, Tamassia, Goldwasser
    • используется в Беркли США как опциональный учебник по введению в CS
    • смотрите мой отчет по книги по Python ниже. Эта книга содержит те же темы.

Python

Опциональные книги

**Некоторые рекомендую эти книги, но я думаю это перебор, если только вы не инженер-программист с большим опытом работы и не ожидаете более сложного собеседования.

  • Руководство по разработке алгоритмов (Skiena)

    • Как обзор и описание проблем

    • Некоторые алгоритмы вряд ли попадутся вам на собеседовании.

    • Эта книга состоит из 2-х частей:

      • классный учебник по структурам данных и алгоритмам
        • преимущества:
          • отличный учебник, содержащий обзор существующих алгоритмов
          • автор описывает реальный опыт решения задач как академических, так и промышленных
          • примеры кода написаны на C
        • недостатки:
          • местами изложение может быть не очевидным и не понятным как в CLRS (Cormen, Leiserson, Rivest, Stein), некоторые темы лучше описаны в CLRS
          • главы 7, 8, 9 сложно понять, некоторые вещи плохо разъяснены или требуют больших знаний чем есть у меня
          • не поймите меня не правильно: Мне нравиться Skiena, ее стиль и манера изложения, но я не могу стать физически Stony Brook.
      • каталог алгоритмов:
        • это реальная причина, почему следует купить эту книгу.
        • о том как дойти до этой части. Обновлю, когда изучу этот раздел.
    • Цитата Йеги: "Больше чем какая-либо другая книга, эта помогла мне понять насколько банальны задачи на графы - они должны быть в инструментарии каждого программиста. Книга так же включает в себя разбор базовых структур данных и алгоритмов сортировки, что является приятным бонусом. Но важнейшей частью стала вторая часть книги, которая написана как энциклопедия, описывающая большое количество различных алгоритмических задач и способов их решения без лишних деталей. Почти каждая страница-описание содержит изображение, облегчающее запоминание. Это полезный способ, позволяющий запомнить и в последствии идентифицировать сотни типов задач."

    • Можете ее арендовать

    • Half.com - отличный ресурс, где можно заказать книги по выгодным ценам.

    • Ответы:

    • Опечатки

  • Введение в алгоритмы

    • Важно: Чтение этой книги будет полезно только для повторения алгоритмов и структур данных. Она не научит вас программировать.
    • Цитата Йеги: "Но если вы хотите идти на собеседование, отложите его пока не изучите эту книгу."
    • Half.com - отличный ресурс, где можно заказать книги по выгодным ценам.
    • известная как CLR, иногда CLRS, потому что Stein опоздал на игру
  • Жемчужины программирования

    • В первых двух главах представлены решения задач программирования (в некоторых из них используются устаревшие типы данных), но это только введение. Это руководство по разработке программ и архитектуре, такое же как Code Complete, но более краткое.
  • "Алгоритмы и программирование: Проблемы и решения" автор Shen

    • Отличная книга, но после разбора нескольких задач написанных на Pascal я разочаровался в его синтаксисе.
    • Лучше провести время решая задачи по программированию из других книг или онлайн ресурсов.

Перед тем как вы начнете

Я создавал эту учебную программу на протяжении нескольких месяцев своими руками.

Ниже я описал некоторые ошибки, которые я совершил. Это поможет вам их избежать.

1. Вы не сможете сразу запомнить все

Я смотрел часами видео делая заметки, но спустя несколько месяцев многое из этого я не помнил. После чего потратил 3 дня разбираясь в своих заметках и делая карточки-напоминания(flashcards), для того что бы потом можно было повторить пройденный материал.

Прочитайте пожалуйста эту статью, что бы не совершать моих ошибок:

Как сохранить знания в CS

2. Используйте карточки-напоминания

Для решения этой проблемы я сделал не большой сайт, на котором можно добавлять карточки двух типов: общие и с кодом. Каждая карта имеет разный формат.

Я сделал мобильную версию сайта и могу читать карточки на мобильном телефоне или планшете.

Сделай свой собственный бесплатно:

Заметка о карточках: в первый раз вы сразу вспомните ответ, но не помечайте эту карточку как изученную. Нужно просмотреть много раз карточку и ответить правильно прежде чем вы действительно ее запомните. Повторение позволяет мозгу надолго запомнить материал.

В качестве альтернативы вы можете использовать сайт Anki, который мне рекомендовали много раз. Он использует систему повторений для того что бы помочь вам запомнить. Это ресурс user-friendly, доступен на всех платформах и имеет возможность синхронизации с облаком. На платформе iOS стоит 25$ на других бесплатный.

Моя база данных в формате Anki: https://ankiweb.net/shared/info/25173560 (спасибо @xiewenya)

3. Повторение, повторение, повторение

У меня постоянно с собой шпаргалки по ASCII, стеку OSI, Big-O нотации и другим темам. Я повторяю их когда у меня есть свободное время.

Делай перерывы от программирования на пол часа и повторяй свои карточки.

4. Фокусируйтесь

Есть много отвлекающих факторов, на которые тратится время. Сосредотачиваться и концентрироваться сложно.

То, что не охватывает этот учебный план

Это список персональных тем, взятых из заметок Google по подготовке к собеседованию. Это распространенные технологии, но они не встречаются в других ресурсах:

  • SQL
  • JavaScript
  • HTML, CSS и другие front-end технологии

План на день

Для изучения некоторых тем требуется один день, для других несколько. Некоторые нужно только изучить и не нужно программировать.

Каждый день я беру одну тему из списка ниже, смотрю видео на эту тему и программирую, используя пройденный материал:

  • C - используя структуры и функции, которые в качестве аргументов принимают указатель на структуру или что-нибудь еще.
  • C++ - без использования встроенных типов
  • C++ - используя встроенные типы, такие как std::list для связанного списка
  • Python - используя встроенные типы (для практики на Python)
  • написание тестов для проверки правильности кода, иногда просто используя выражение assert()
  • Вы можете программировать на Java или других языках, это только лишь мой выбор.

Вам не нужны все эти языки для собеседования, нужен только один один язык для собеседования.

Зачем нужно программировать на нескольких языках:

  • Практика, практика, практика пока это не надоедает мне я программирую
  • Работа в рамках установленных ограничений (выделение/освобождение памяти без помощи сборщика мусора (кроме Python))
  • Используйте встроенные типы, потому как у меня есть опыт использования встроенных инструментах в реальных проектах (нет смысла в написание своей реализации связанного списка для продакшена)

У меня может и не будет времени на все это, но я попробую.

Вы можете посмотреть на мой код тут:

Вам не нужно запоминать внутренности каждого алгоритма.

Пишите код на доске или листе бумаги, но не компьютере. Проверяйте на простых входных данных. Затем тестируйте на компьютере.

Необходимые знания

Сложность алгоритмов / Big-O / Асимптотический анализ

Структуры данных

  • Массивы

    • Реализация динамического вектора.
    • Описание:
    • Реализация вектора (изменяемый массив с автоматическим изменением размера):
      • Тренируйтесь программировать используя массивы, указатели и арифметику указателей для перехода к индексу вместо индексации.
      • выделение памяти для массива
        • можно выделить память для массива целых чисел, просто не используя его возможности
        • начиная с 16, или если начальная цифра больше, использовать степень 2 - 16, 32, 64, 128
      • size() - количество элементов
      • capacity() - количество элементов которое он может содержать
      • is_empty()
      • at(index) - возвращает элемент по индексу, изменяет размер, если индекс выходит за пределы
      • push(item)
      • insert(index, item) - вставка элемента по индексу, сдвигает значение по индексу и следующие за ним элементы вправо
      • prepend(item) - может вставить элемент выше индекса 0
      • pop() - удалить последний элемент, вернуть значение
      • delete(index) - удаляет элемент по индексу, сдвигает все следующие за ним элементы в лево
      • remove(item) - ищет элементы по значению и удаляет их, даже если их несколько
      • find(item) - ищет элемент по значению и возвращает индекс первого найденного элемента, возвращает -1 если ничего не найденно
      • resize(new_capacity) // private function
        • когда массив полностью заполнен, увеличивает его размер вдвое
        • при добавлении элемента, если размер массива 1/4 от общего размера, увеличиваем на половину
    • Время
      • O(1) для операций add/remove в конце (амортизируется для размещения большего объема), index, или update
      • O(n) для insert/remove в любом месте
    • Работа с памятью
      • смежные в памяти, это помогает повысить производительность
      • необходимое пространство = (размер массива, который >= n) * размер элемента, но даже если 2n, по прежнему O(n)
  • Связные списки (Linked Lists)

    • Описание:
    • C Code (video) - не все видео целиком, только кусочки об узлах и распределении памяти.
    • Связные списки vs Массивы:
    • why you should avoid linked lists (video)
    • Ага, попался: тебе нужны знания указетелей на указатели: (для тех случаев, когда ты передаешь указатель функции, которая может менять адрес, куда указывает указатель) Это страница просто для того, чтобы понять указатели на указатели. Читабельность и обслуживаемость страдает из-за искусность.
    • воплотить в жизнь (я сделал это с помощью указателя на хвост и без):
      • size() - возвращает количество элементов в листе
      • empty() - возвращет true если список пуст
      • value_at(n) - возращет значение n-го элемента, где 0 - первый элемент
      • push_front(value) - добавляет элемент в начало списка
      • pop_front() - удаляет первый и возращает его значение
      • push_back(value) - добавляет элемент в конец списка
      • pop_back() - удаляет последний и возращает его значение
      • front() - возращает значение первого элемента в списке
      • back() - возращает значение последнего элемента в списке
      • insert(index, value) - помещает значение (value) в элемент по индексу (index), при этом заменяемый элемент добавлен в список как новый элемент
      • erase(index) - удаляет узел (элемент) по данному индексу
      • value_n_from_end(n) - возращает значение n-го элемента c конца списка
      • reverse() - реверсирует весь список
      • remove_value(value) - удаляет первый элемент в списке с указанным значением (value)
    • Двусвязный список
  • Стек

  • Очередь

    • Использование очереди First-In First-Out(video)
    • Очередь (video)
    • Circular buffer/FIFO
    • Очередь с приоритетом (video)
    • Реализация с использованием связанного списка и указателя на последний элемент(tail):
      • enqueue(value) - добавляет элемент в конец очереди
      • dequeue() - возвращает значение и удаляет из очереди последний добавленный элемент(front)
      • empty()
    • Реализация с приминением массива фиксированного размера:
      • enqueue(value) - добавляет элемент в конец очереди
      • dequeue() - возвращает значение и удаляет из очереди последний добавленный элемент
      • empty()
      • full()
    • Затраты:
      • плохая реализация с приминением связанного списка когда элемент добавляется в начало очереди и удаляется с конца очереди за O(n), операция dequeue в таком случае будет требовать каждый раз обхода всего списка
      • enqueue: O(1) (amortized, связанный список и массив [probing])
      • dequeue: O(1) (связанный список и массив)
      • empty: O(1) (связанный список и массив)
  • Хеш-таблица

Больше знаний

Trees

Sorting

If you need more detail on this subject, see "Sorting" section in Additional Detail on Some Subjects

Графы

Графы могут быть использованы для представления многих задач в области CS, поэтому раздел включает в себя такие темы как деревья и сортировку.

Вы найдете больше практических задач на графах в книге Стивена Скина (см раздел книги ниже) и в книгах о прохождении интервью.

Еще больше знаний


System Design, Scalability, Data Handling


Final Review

This section will have shorter videos that can you watch pretty quickly to review most of the important concepts.
It's nice if you want a refresher often.

Coding Question Practice

Now that you know all the computer science topics above, it's time to practice answering coding problems.

Coding question practice is not about memorizing answers to programming problems.

Why you need to practice doing programming problems:

  • problem recognition, and where the right data structures and algorithms fit in
  • gathering requirements for the problem
  • talking your way through the problem like you will in the interview
  • coding on a whiteboard or paper, not a computer
  • coming up with time and space complexity for your solutions
  • testing your solutions

There is a great intro for methodical, communicative problem solving in an interview. You'll get this from the programming interview books, too, but I found this outstanding: Algorithm design canvas

My Process for Coding Interview (Book) Exercises

No whiteboard at home? That makes sense. I'm a weirdo and have a big whiteboard. Instead of a whiteboard, pick up a large drawing pad from an art store. You can sit on the couch and practice. This is my "sofa whiteboard". I added the pen in the photo for scale. If you use a pen, you'll wish you could erase. Gets messy quick.

my sofa whiteboard

Supplemental:

Read and Do Programming Problems (in this order):

See Book List above

Coding exercises/challenges

Once you've learned your brains out, put those brains to work. Take coding challenges every day, as many as you can.

Challenge sites:

Maybe:

Once you're closer to the interview

Your Resume

Be thinking of for when the interview comes

Think of about 20 interview questions you'll get, along with the lines of the items below. Have 2-3 answers for each. Have a story, not just data, about something you accomplished.

  • Why do you want this job?
  • What's a tough problem you've solved?
  • Biggest challenges faced?
  • Best/worst designs seen?
  • Ideas for improving an existing Google product.
  • How do you work best, as an individual and as part of a team?
  • Which of your skills or experiences would be assets in the role and why?
  • What did you most enjoy at [job x / project y]?
  • What was the biggest challenge you faced at [job x / project y]?
  • What was the hardest bug you faced at [job x / project y]?
  • What did you learn at [job x / project y]?
  • What would you have done better at [job x / project y]?

Have questions for the interviewer

Some of mine (I already may know answer to but want their opinion or team perspective):
  • How large is your team?
  • What does your dev cycle look like? Do you do waterfall/sprints/agile?
  • Are rushes to deadlines common? Or is there flexibility?
  • How are decisions made in your team?
  • How many meetings do you have per week?
  • Do you feel your work environment helps you concentrate?
  • What are you working on?
  • What do you like about it?
  • What is the work life like?

Once You've Got The Job

Congratulations!

Keep learning.

You're never really done.


*****************************************************************************************************
*****************************************************************************************************

Everything below this point is optional. These are my recommendations, not Google's.
By studying these, you'll get greater exposure to more CS concepts, and will be better prepared for
any software engineering job. You'll be a much more well-rounded software engineer.

*****************************************************************************************************
*****************************************************************************************************

Additional Books

Additional Learning

--

Additional Detail on Some Subjects

I added these to reinforce some ideas already presented above, but didn't want to include them
above because it's just too much. It's easy to overdo it on a subject.
You want to get hired in this century, right?

Video Series

Sit back and enjoy. "Netflix and skill" :P

Computer Science Courses