mirror of
https://github.com/donnemartin/interactive-coding-challenges.git
synced 2024-03-22 13:11:13 +08:00
changed solutions to challenge Arrays & Strings:
added a test for checking two empty strings, the proposed solutions did not pass this test although the specification requires it to return False in this case changed the proposed solutions to pass this additional test added a new solution
This commit is contained in:
parent
d898520439
commit
c6d8f406fd
|
@ -124,6 +124,7 @@
|
||||||
" def test_permutation(self, func):\n",
|
" def test_permutation(self, func):\n",
|
||||||
" assert_equal(func(None, 'foo'), False)\n",
|
" assert_equal(func(None, 'foo'), False)\n",
|
||||||
" assert_equal(func('', 'foo'), False)\n",
|
" assert_equal(func('', 'foo'), False)\n",
|
||||||
|
" assert_equal(func('', ''), False)\n",
|
||||||
" assert_equal(func('Nib', 'bin'), False)\n",
|
" assert_equal(func('Nib', 'bin'), False)\n",
|
||||||
" assert_equal(func('act', 'cat'), True)\n",
|
" assert_equal(func('act', 'cat'), True)\n",
|
||||||
" assert_equal(func('a ct', 'ca t'), True)\n",
|
" assert_equal(func('a ct', 'ca t'), True)\n",
|
||||||
|
@ -159,7 +160,7 @@
|
||||||
],
|
],
|
||||||
"metadata": {
|
"metadata": {
|
||||||
"kernelspec": {
|
"kernelspec": {
|
||||||
"display_name": "Python 3",
|
"display_name": "Python [default]",
|
||||||
"language": "python",
|
"language": "python",
|
||||||
"name": "python3"
|
"name": "python3"
|
||||||
},
|
},
|
||||||
|
@ -173,9 +174,9 @@
|
||||||
"name": "python",
|
"name": "python",
|
||||||
"nbconvert_exporter": "python",
|
"nbconvert_exporter": "python",
|
||||||
"pygments_lexer": "ipython3",
|
"pygments_lexer": "ipython3",
|
||||||
"version": "3.5.0"
|
"version": "3.6.3"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"nbformat": 4,
|
"nbformat": 4,
|
||||||
"nbformat_minor": 0
|
"nbformat_minor": 2
|
||||||
}
|
}
|
||||||
|
|
|
@ -90,7 +90,7 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"cell_type": "code",
|
"cell_type": "code",
|
||||||
"execution_count": 1,
|
"execution_count": 21,
|
||||||
"metadata": {
|
"metadata": {
|
||||||
"collapsed": false
|
"collapsed": false
|
||||||
},
|
},
|
||||||
|
@ -99,7 +99,7 @@
|
||||||
"class Permutations(object):\n",
|
"class Permutations(object):\n",
|
||||||
"\n",
|
"\n",
|
||||||
" def is_permutation(self, str1, str2):\n",
|
" def is_permutation(self, str1, str2):\n",
|
||||||
" if str1 is None or str2 is None:\n",
|
" if not str1 or not str2:\n",
|
||||||
" return False\n",
|
" return False\n",
|
||||||
" return sorted(str1) == sorted(str2)"
|
" return sorted(str1) == sorted(str2)"
|
||||||
]
|
]
|
||||||
|
@ -141,7 +141,7 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"cell_type": "code",
|
"cell_type": "code",
|
||||||
"execution_count": 2,
|
"execution_count": 24,
|
||||||
"metadata": {
|
"metadata": {
|
||||||
"collapsed": false
|
"collapsed": false
|
||||||
},
|
},
|
||||||
|
@ -153,7 +153,7 @@
|
||||||
"class PermutationsAlt(object):\n",
|
"class PermutationsAlt(object):\n",
|
||||||
"\n",
|
"\n",
|
||||||
" def is_permutation(self, str1, str2):\n",
|
" def is_permutation(self, str1, str2):\n",
|
||||||
" if str1 is None or str2 is None:\n",
|
" if not str1 or not str2:\n",
|
||||||
" return False\n",
|
" return False\n",
|
||||||
" if len(str1) != len(str2):\n",
|
" if len(str1) != len(str2):\n",
|
||||||
" return False\n",
|
" return False\n",
|
||||||
|
@ -166,6 +166,55 @@
|
||||||
" return unique_counts1 == unique_counts2"
|
" return unique_counts1 == unique_counts2"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"cell_type": "markdown",
|
||||||
|
"metadata": {},
|
||||||
|
"source": [
|
||||||
|
"## Algorithm: Array Removal\n",
|
||||||
|
" \n",
|
||||||
|
"Since a permuation is a symmetric relation (A is a permutation of B iff B is a permutation of A) one only needs to check if one can rebuild the first string using all the characters of the second.\n",
|
||||||
|
"\n",
|
||||||
|
"Steps:\n",
|
||||||
|
"* Check if the strings are not None or empty\n",
|
||||||
|
"* Turn the second string into a list of characters\n",
|
||||||
|
"* For each character in the first string:\n",
|
||||||
|
" * If the character does not appear in the list, return False\n",
|
||||||
|
" * Else: remove the character from the list\n",
|
||||||
|
"* Return True if the list is empty (we used up all characters), else return False\n",
|
||||||
|
"\n",
|
||||||
|
"Complexity:\n",
|
||||||
|
"* Time: O(n)\n",
|
||||||
|
"* Space: O(n)"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"cell_type": "markdown",
|
||||||
|
"metadata": {},
|
||||||
|
"source": [
|
||||||
|
"## Code: Array Lookup"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"cell_type": "code",
|
||||||
|
"execution_count": 39,
|
||||||
|
"metadata": {},
|
||||||
|
"outputs": [],
|
||||||
|
"source": [
|
||||||
|
"class PermutationsArray(object):\n",
|
||||||
|
"\n",
|
||||||
|
" def is_permutation(self, str1, str2):\n",
|
||||||
|
" if not str1 or not str2:\n",
|
||||||
|
" return False\n",
|
||||||
|
" \n",
|
||||||
|
" chars = list(str2) \n",
|
||||||
|
" for char in str1:\n",
|
||||||
|
" if char not in chars:\n",
|
||||||
|
" return False\n",
|
||||||
|
" else:\n",
|
||||||
|
" chars.remove(char)\n",
|
||||||
|
" return len(chars) == 0"
|
||||||
|
]
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"cell_type": "markdown",
|
"cell_type": "markdown",
|
||||||
"metadata": {},
|
"metadata": {},
|
||||||
|
@ -175,7 +224,7 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"cell_type": "code",
|
"cell_type": "code",
|
||||||
"execution_count": 3,
|
"execution_count": 40,
|
||||||
"metadata": {
|
"metadata": {
|
||||||
"collapsed": false
|
"collapsed": false
|
||||||
},
|
},
|
||||||
|
@ -198,6 +247,7 @@
|
||||||
" def test_permutation(self, func):\n",
|
" def test_permutation(self, func):\n",
|
||||||
" assert_equal(func(None, 'foo'), False)\n",
|
" assert_equal(func(None, 'foo'), False)\n",
|
||||||
" assert_equal(func('', 'foo'), False)\n",
|
" assert_equal(func('', 'foo'), False)\n",
|
||||||
|
" assert_equal(func('', ''), False)\n",
|
||||||
" assert_equal(func('Nib', 'bin'), False)\n",
|
" assert_equal(func('Nib', 'bin'), False)\n",
|
||||||
" assert_equal(func('act', 'cat'), True)\n",
|
" assert_equal(func('act', 'cat'), True)\n",
|
||||||
" assert_equal(func('a ct', 'ca t'), True)\n",
|
" assert_equal(func('a ct', 'ca t'), True)\n",
|
||||||
|
@ -212,6 +262,8 @@
|
||||||
" try:\n",
|
" try:\n",
|
||||||
" permutations_alt = PermutationsAlt()\n",
|
" permutations_alt = PermutationsAlt()\n",
|
||||||
" test.test_permutation(permutations_alt.is_permutation)\n",
|
" test.test_permutation(permutations_alt.is_permutation)\n",
|
||||||
|
" permutations_array = PermutationsArray()\n",
|
||||||
|
" test.test_permutation(permutations_array.is_permutation)\n",
|
||||||
" except NameError:\n",
|
" except NameError:\n",
|
||||||
" # Alternate solutions are only defined\n",
|
" # Alternate solutions are only defined\n",
|
||||||
" # in the solutions file\n",
|
" # in the solutions file\n",
|
||||||
|
@ -224,7 +276,7 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"cell_type": "code",
|
"cell_type": "code",
|
||||||
"execution_count": 4,
|
"execution_count": 41,
|
||||||
"metadata": {
|
"metadata": {
|
||||||
"collapsed": false
|
"collapsed": false
|
||||||
},
|
},
|
||||||
|
@ -233,6 +285,7 @@
|
||||||
"name": "stdout",
|
"name": "stdout",
|
||||||
"output_type": "stream",
|
"output_type": "stream",
|
||||||
"text": [
|
"text": [
|
||||||
|
"Success: test_permutation\n",
|
||||||
"Success: test_permutation\n",
|
"Success: test_permutation\n",
|
||||||
"Success: test_permutation\n"
|
"Success: test_permutation\n"
|
||||||
]
|
]
|
||||||
|
@ -245,7 +298,7 @@
|
||||||
],
|
],
|
||||||
"metadata": {
|
"metadata": {
|
||||||
"kernelspec": {
|
"kernelspec": {
|
||||||
"display_name": "Python 3",
|
"display_name": "Python [default]",
|
||||||
"language": "python",
|
"language": "python",
|
||||||
"name": "python3"
|
"name": "python3"
|
||||||
},
|
},
|
||||||
|
@ -259,9 +312,9 @@
|
||||||
"name": "python",
|
"name": "python",
|
||||||
"nbconvert_exporter": "python",
|
"nbconvert_exporter": "python",
|
||||||
"pygments_lexer": "ipython3",
|
"pygments_lexer": "ipython3",
|
||||||
"version": "3.5.0"
|
"version": "3.6.3"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"nbformat": 4,
|
"nbformat": 4,
|
||||||
"nbformat_minor": 0
|
"nbformat_minor": 2
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,6 +6,7 @@ class TestPermutation(object):
|
||||||
def test_permutation(self, func):
|
def test_permutation(self, func):
|
||||||
assert_equal(func(None, 'foo'), False)
|
assert_equal(func(None, 'foo'), False)
|
||||||
assert_equal(func('', 'foo'), False)
|
assert_equal(func('', 'foo'), False)
|
||||||
|
assert_equal(func('', ''), False)
|
||||||
assert_equal(func('Nib', 'bin'), False)
|
assert_equal(func('Nib', 'bin'), False)
|
||||||
assert_equal(func('act', 'cat'), True)
|
assert_equal(func('act', 'cat'), True)
|
||||||
assert_equal(func('a ct', 'ca t'), True)
|
assert_equal(func('a ct', 'ca t'), True)
|
||||||
|
@ -20,6 +21,8 @@ def main():
|
||||||
try:
|
try:
|
||||||
permutations_alt = PermutationsAlt()
|
permutations_alt = PermutationsAlt()
|
||||||
test.test_permutation(permutations_alt.is_permutation)
|
test.test_permutation(permutations_alt.is_permutation)
|
||||||
|
permutations_array = PermutationsArray()
|
||||||
|
test.test_permutation(permutations_array.is_permutation)
|
||||||
except NameError:
|
except NameError:
|
||||||
# Alternate solutions are only defined
|
# Alternate solutions are only defined
|
||||||
# in the solutions file
|
# in the solutions file
|
||||||
|
|
Loading…
Reference in New Issue
Block a user