- Notifications
You must be signed in to change notification settings - Fork0
dev-xero/python-algorithms-exercise-practice
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
🐍 Exercise solutions for chapter 1.1 written in Python
- is_between_zero_and_one()
- to_binary_string()
- print_two_dm_boolean_array()
- print_two_dm_int_array()
- print_int_array()
- matrix_transposition()
- lg()
- Fibonacci.fib()
- Fibonacci.fast_fib()
- fact()
- binary_search()
- brute_force_search()
One interesting implementation is this algorithm to compute fibonacci sequences (exercise 1.1.19). It runs in O(1) time provided that the cache contains the previous two sequences. Generating the previous sequences is usually done using loops.
@staticmethoddeffast_fib(n:int,cache: {int:int})->int:"""Fibonacci sequence algorithm utilizing dynamic programing and memoization"""ifn==0:cache[n]=0return0ifn==1:cache[n]=1return1cache[n]=cache[n-2]+cache[n-1]returncache[n]
It's also worth noting that I've implemented brute force search recursively here as opposed to the iterative approach in the Javasource
defbrute_force_search(key:int,the_array: [int],index:int)->int:"""Returns the index of the key if present, otherwise -1 using brute force search"""ifindex==len(the_array):return-1ifthe_array[index]==key:returnindexreturnbrute_force_search(key,the_array,index+1)
These were originally implemented in Java. You can find the sourcehere
About
🐍 Exercise solutions for chapter 1.1 written in Python
Topics
Resources
Uh oh!
There was an error while loading.Please reload this page.
Stars
Watchers
Forks
Releases
No releases published
Packages0
No packages published