Skip to content

Commit 1399276

Browse files
treyhunnerbehrtam
authored andcommitted
Add flatten array exercise
1 parent 8b08a8f commit 1399276

3 files changed

Lines changed: 65 additions & 0 deletions

File tree

config.json

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -28,6 +28,7 @@
2828
"largest-series-product",
2929
"kindergarten-garden",
3030
"grade-school",
31+
"flatten-array",
3132
"roman-numerals",
3233
"space-age",
3334
"grains",
@@ -222,6 +223,12 @@
222223
"topics": [
223224
]
224225
},
226+
{
227+
"slug": "flatten-array",
228+
"difficulty": 1,
229+
"topics": [
230+
]
231+
},
225232
{
226233
"slug": "roman-numerals",
227234
"difficulty": 1,

exercises/flatten-array/example.py

Lines changed: 18 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,18 @@
1+
def is_iterable(thing):
2+
try:
3+
iter(thing)
4+
except TypeError:
5+
return False
6+
else:
7+
return True
8+
9+
10+
def flatten(iterable):
11+
"""Flatten a list of lists."""
12+
flattened = []
13+
for item in iterable:
14+
if is_iterable(item) and not isinstance(item, (str, bytes)):
15+
flattened += flatten(item)
16+
elif item is not None:
17+
flattened.append(item)
18+
return flattened
Lines changed: 40 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,40 @@
1+
import unittest
2+
3+
from flatten_array import flatten
4+
5+
6+
class FlattenArrayTests(unittest.TestCase):
7+
8+
def test_no_nesting(self):
9+
self.assertEqual(flatten([0, 1, 2]), [0, 1, 2])
10+
11+
def test_one_level_nesting(self):
12+
self.assertEqual(flatten([0, [1], 2]), [0, 1, 2])
13+
14+
def test_two_level_nesting(self):
15+
self.assertEqual(flatten([0, [1, [2, 3]], [4]]), [0, 1, 2, 3, 4])
16+
17+
def test_empty_nested_lists(self):
18+
self.assertEqual(flatten([[()]]), [])
19+
20+
def test_with_none_values(self):
21+
inputs = [0, 2, [[2, 3], 8, [[100]], None, [[None]]], -2]
22+
expected = [0, 2, 2, 3, 8, 100, -2]
23+
self.assertEqual(flatten(inputs), expected)
24+
25+
def test_six_level_nesting(self):
26+
inputs = [1, [2, [[3]], [4, [[5]]], 6, 7], 8]
27+
expected = [1, 2, 3, 4, 5, 6, 7, 8]
28+
self.assertEqual(flatten(inputs), expected)
29+
30+
def test_all_values_are_none(self):
31+
inputs = [None, [[[None]]], None, None, [[None, None], None], None]
32+
expected = []
33+
self.assertEqual(flatten(inputs), expected)
34+
35+
def test_strings(self):
36+
self.assertEqual(flatten(['0', ['1', '2']]), ['0', '1', '2'])
37+
38+
39+
if __name__ == '__main__':
40+
unittest.main()

0 commit comments

Comments
 (0)