Skip to content

Latest commit

 

History

History
316 lines (203 loc) · 13.2 KB

README.md

File metadata and controls

316 lines (203 loc) · 13.2 KB

Pythonified Coding Interview Bootcamp Exercises

This repo contains Pythonic versions of exercises based on Stephen Grider's The Coding Interview Bootcamp: Algorithms + Datastructures found on Udemy. The JavaScript repo is here.

I created this, as I wanted to apply what I learned in JavaScript from Stephen's course, toward learning Python.

This repo is not intended to be a rip off of Stephen's work or a replacement for his very informative course targeted at JavaScript. Consider it more of a Pythonic ode.

💁 I pinged him about doing this, but didn't get a response.

This repo is also not a substitute for the ton of material he covers, erudite teaching he provides, and the practical experience he shares throughout the course lectures. In fact, you're not likely to get a whole lot out of these exercises without having access to the course material. So if you really want a good start toward learning these the concepts behind these exercises (in JavaScript) and then apply them in Python, go buy his course and enjoy what I've created here! 🌈 🦄 🌈 🐱 🌈 🐑 🌈

Features

  • Oodles of exercises to practice challenging coding questions
  • Extensive unit tests to verify your solutions
  • Example solutions (often more than one) for every exercise

Requirements

  • Python 3: some tests won't work if you use Python 2
  • A testing framework ( e.g. pytest or unnitest )
  • A text editor: Atom, Sublime Text, Vim, Visual Studio Code, etc.
  • A terminal

💾 If you're running Windows 10 try Windows Subsystem for Linux.

🐍 There is an excellent Python extension for Visual Studio Code. Check it out here.

Installation

Clone this repo

  1. Go to a place on your machine where you want to download this repo (e.g. cd ~/workspace/):
  2. Run one of the following commands:

SSH

git clone [email protected]:kimfucious/pythonic_algocasts.git

HTTPS

git clone https://github.com/kimfucious/pythonic_algocasts.git 

This repo has both a requirements.txt file and a Pipfile for making installing dependencies easy.

You don't need to install any dependencies, if you're planning on just using unittest to test your solutions.

If you want to use pytest, you can install it manually (see below); otherwise it will be installed by pip or pipenv along with the following packages:

  • A beta version of HTMLTestRunner (creates HTML reports)
  • liveReload (small dev server to display HTML reports)
  • pylint (a Python code linter)
  • other sub-dependencies

Installing dependencies using pip

I'm using pip3 throughout this documentation, but pip should also work fine.

You probably already have pip, but here's some info on installation and upgrading.

You probably also want to create an new Python environment. To do that, navigate to this downloaded repo's root directory, and run the following:

python3 -m venv env
source env/bin/activate

☝️ The above commands assume you are using bash or zsh. Refer to the below or see here for using venv in other shells.

Platform Shell Command to activate virtual environment
Posix bash/zsh $ source /bin/activate
fish $ . /bin/activate.fish
csh/tcsh $ source /bin/activate.csh
Windows cmd.exe C:> \Scripts\activate.bat
PowerShell PS C:> \Scripts\Activate.ps1

Run pip3 list, and you should see only two files:

Package    Version
---------- -------
pip        10.0.1 
setuptools 39.0.1 

You'll get prompted to upgrade pip at this point. Go ahead and do that, if you want.

Next, run:

pip3 install -r requirements.txt

Once this completes, run pip3 list again, and Bob's your uncle.

Installing using Pipenv

Pipenv is awesome. You can learn about it here.

After installing Pipenv, navigate to this project's root and run the following:

pipenv install
pipenv shell

Contents

☝️ Do not remove any of the __init__.py files from within the repo, or it will break test discovery.

Exercises

Starter files for each exercise with instructions that describe what the solution should be.

While you can, for the most part, approach these exercises in any order. The course does tend to build upon itself, so you may want to follow the order in which the lectures are covered in Stephen's course.

Order of exercises

  1. String Reversal (reversestring)
  2. Palindromes
  3. Integer Reversal (reverseint)
  4. MaxChars
  5. FizzBuzz
  6. List Chunking (chunk)
  7. Anagrams
  8. Sentance Capitalization (capitalize)
  9. Printing Steps (steps)
  10. Two Sided Steps (pyramid)
  11. Vowels
  12. Matrix Spiral (matrix)
  13. Fibonacci (fib and fib_memoized)
  14. Queue
  15. Weave
  16. Stack
  17. Queue From Stack (qfroms)
  18. Linked Lists (linkedlist)
  19. Midpoint
  20. Circular
  21. From Last (from last)
  22. Tree
  23. Level Width (levelwidth)
  24. Binary Search Tree (bst)
  25. Validating Binary Search Trees (validate)
  26. Events
  27. Bubble Sort, Selection Sort, and Merge Sort (sorting)

Helpers

Some of the exercies rely on pre-built components (probably not the right word), like: classes, linked lists, queues, and stacks. You'll build such things as you work through the excercises; however, these helpers are in place for exercises with a different, specific focus.

Misc

There are two html files in here:

  1. The events_example.html file is for the events exercise. Frankly, you won't get much out of this unless you have access to Stephen's course.
  2. The linkedlist_directions.html file is a set of instructions for the fairly long linked list exercise.

Reports

This is where HTML test reports will be generated.

I've setup an HTML report generator that will allow you to display the test results in a web browser.

You can get this going by running the following command from the root of this project.

python3 reports.py

To view the reports, open http://localhost:8080 in your browser, after running the above command.

There are a few things happening to make this work.

  1. I've setup a test suite containing all of the tests in the run_all_tests.py file.
  2. This file also uses James Sloan's beta version of HTMLTestRunner. I'm using the beta, because James has made it possible to combine multiple test cases into one report. If/when this pull request comes through, I'll update this project to use the updated release.
  3. The reports.py file launches livereload, which is a dev server that serves up the test_results.html file.
  4. livereload is setup to watch all *.py files in the exercises directory. Any changes to these files, kicks off the run_all_tests.py process, which overwrites any existing test_results.html file in the reports directory, it then waits a few seconds, and automatically reloads the browser window.

☝️ If you're running into an issue where the browser refreshes before the tests complete, like if you're running fib(39), you can adjust the delay in the reports.py file on the line shown below:

server.watch("./exercises/*.py",
             shell("python3 run_all_tests.py --quiet"), delay=3)

This process is not perfect. Admittedly, the console output is not pretty. If you want nice output in the console, checkout pytest in Testing. Also, if there's something really wrong (e.g. SyntaxError) with an exercise solution, the process will crash before any report is generated. This is usually indicated by something red in the console output, that might resemble this with a bunch of nasty stuff after it, usually ending with the type of error being thrown:

[E 180819 00:44:57 server:75] yadda, yadda, yadda SyntaxError: invalid syntax...

When this does happen, the report will reload in the browser, but it will be using old data so the results will not be accurate.

At this point, you can try running your tests manually (see Testing below) to see more clearly what's going on and fix your solution.

Lastly, to generate HTML reports manually without livereload, run the following from the root directory:

python3 run_all_tests.py

Solutions

Here are the examples solutions to the exercises that you can use to compare against your own work or to peek at for inspiration.

Feel free to recommend your solution(s) via a pull request if you come up with anything better, cleaner, clearer, more-pythonic, etc. Please use doctype to document your solutions, instead of comments.

Example:

def function(x):
  """
  My super cool solution is based on using kittens, rainbows, and lambdas.
  You can read about those things at http://kittensrainbowsandlambdas.org
  """
  pass

🙈 Solutions containing advertisements or other forms of spam/self-promotion won't be considered. This is a learning space, not a marketplace.

Tests

There is one test file for each exercise. The naming convention should make it evident as to what tests what.

All of the test files should be considered done, meaning that you should not need to edit any of them, except for commenting out the @unittest.skip() lines when you're ready to test (see Skipping and Unskipping Tests). They should just work and are just there to test the solutions that you create for the exercises.

🪲 If you find any mistakes in the tests or have any recomendations to improve them, please raise an issue.

Some of the test files contain one or more test cases (i.e. Classes) and these can contain one to several test methods. See the Testing section for more info on tests.

Testing

Note that the __init__.py files that you see in the directory structure (and the directory structure itself) are there to enable test discovery. Don't move things around or delete any __init__.py files, unless you know that you really want to.

Testing Frameworks

At the risk of sounding redundant, all tests have been tested using both unittest and pytest.

While unittest is built in to Python, pytest requires installation.

Here's some documentation:

Test Discovery

To discover all tests, if you're using unittest, you can run discovery by doing the following:

  1. Navigate to the root directory of this repo in your terminal
  2. Run python3 -m unittest discover

As far as I know, pytest doesn't have a discovery option, nor is it needed. And, along those lines, python3 -m unittest will also discover tests, so take that for what it is.

Running Tests

To run all unit tests:

  1. Navigate to the root directory of this repo in your terminal
  2. Do one of the below:

☝️ Remember that we're using Python 3. Don't forget to type python3 (not python), and don't forget the -m bit.

pytest

python3 -m pytest

unittest

python3 -m unittest

To run an individual unit test:

  1. Navigate to the root directory of this repo.
  2. Run either of the below, where exercise.py is the name of thing you're trying to test, like test_anagrams.py, for example.

📌 You can also navigate to the tests directory, and run python3 -m pytest test_excercise.py.

pytest

python3 -m pytest tests/test_excercise.py

unittest

python3 -m unittest tests/test_excercise.py

💡 adding --verbose to either of the two above commands will give you a more output in your test results.

Skipping and Unskipping Tests

You'll have noticed that all of the tests are skipped when you first try to run them. This is so that you don't see a load of failures and/or errors on exercises that you haven't event attempted to work on yet.

The following line (i.e. decorator) in a test file will skip an entire test case (multiple methods) or single test cases depending on where it's located.

@unittest.skip("skip the following stuff")

In most of the test files, there is one skip decorator located just above the Class defining the test case. In other, more lengthy test files, like Linked List, there might be more cases and, thus, more skip decorators, allowing you to open up the test cases slowly as you progress through the exercises.

To allow a test case to run, simply comment out the decorator, like this (or delete it if you're feeling bold):

# @unittest.skip("skip the following stuff")