120+ interactive Python coding interview challenges (algorithms and data structures). Includes Anki flashcards.
Go to file
2015-06-14 07:17:53 -04:00
arrays-strings Added notebook solving the following: Implement a hash table with set, get, and remove methods. 2015-06-02 17:45:02 -04:00
hacker-rank Added notebook solving the following: HackerRank Maximizing XOR problem.. 2015-05-21 06:05:32 -04:00
images Added notebook solving the following: Compress a string such that aabbb becomes a2b3. 2015-05-04 05:54:50 -04:00
linked-lists Added notebook solving the following: Determine if a linked list is a palindrome. 2015-05-19 17:20:56 -04:00
recursion-dynamic Cleaned up code. 2015-05-30 11:06:39 -04:00
sorting-searching Added notebook solving the following: Implement merge sort. 2015-05-29 06:51:37 -04:00
stacks-queues renamed queue-list.py to queue_list.py to be more consistent with python coding guidelines. 2015-06-02 17:43:58 -04:00
.gitignore Added IPython Notebook templates to .gitignore. 2015-05-31 20:26:46 -04:00
LICENSE Added LICENSE. 2015-04-29 06:38:00 -04:00
README.md Fixed case and space/dash consistency issues. 2015-06-14 07:17:53 -04:00


Wikipedia: Quicksort, Merge Sort

algorithms-data-structures

Continually updated IPython Notebooks containing coding problems and solutions (algorithms and data structures).

Most solutions are in Python.

Index

Arrays and Strings

Linked Lists

Stacks and Queues

Sorting and Searching

Recursion and Dynamic Programming

Trees and Graphs

[Coming Soon]

Bit Manipulation

[Coming Soon]

Scalability and Memory Limits

[Coming Soon]

Concurrency

[Coming Soon]

Hacker Rank and TopCoder

Notebook Installation

Anaconda is a free distribution of the Python programming language for large-scale data processing, predictive analytics, and scientific computing that aims to simplify package management and deployment.

Follow instructions to install Anaconda or the more lightweight miniconda.

To view interactive content or to modify elements within the IPython notebooks, you must first clone or download the repository then run the ipython notebook. More information on IPython Notebooks can be found here.

$ git clone https://github.com/donnemartin/data-science-ipython-notebooks.git
$ cd [downloaded repo directory name]
$ ipython notebook

Credits

Contact Info

Feel free to contact me to discuss any issues, questions, or comments.

License

Copyright 2015 Donne Martin

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.