-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathunit1_lesson_03_understanding_lists.py
194 lines (145 loc) · 5.62 KB
/
unit1_lesson_03_understanding_lists.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
__author__ = 'Kalyan'
from placeholders import *
notes = '''
python list is a ordered mutable sequence of objects. You will see that some
of the ideas/concepts that are introduced in strings also apply to lists
(slicing, indexing etc).
experiment in console to learn and make these tests pass.
'''
def test_list_type():
fruits = ["banana", "orange", "grape"]
assert "list" == type(fruits).__name__
def test_list_len():
fruits = ["banana", "orange", "grape"]
assert 3 == len(fruits)
def test_list_can_be_indexed():
fruits = ["banana", "orange", "grape"]
assert "banana" == fruits[0]
assert "orange" == fruits[1]
assert "grape" == fruits[2]
assert "grape" == fruits[-1]
assert "orange" == fruits[-2]
assert "banana" == fruits[-3]
def test_list_is_mutable():
fruits = ["banana", "orange", "grape"]
fruits[0] = "mango"
assert ["mango","orange","grape"] == fruits #replace __ with expected contents of list
def test_list_can_be_sliced():
"""
Slicing works the same as on strings
"""
fruits = ["banana", "orange", "grape"]
assert [] == fruits[0:0]
#begin : end
assert ["banana", "orange"] == fruits[0:2]
assert ["banana", "orange", "grape"] == fruits[0:5]
assert ["orange"] == fruits[1:-1]
# begin :
assert ['banana', 'orange', 'grape'] == fruits[0:]
assert ['grape'] == fruits[2:]
assert ['banana', 'orange', 'grape'] == fruits[0:]
#: end
assert [] == fruits[:0]
assert ['banana', 'orange'] == fruits[:2]
assert ['banana', 'orange', 'grape'] == fruits[:5]
# note the invariant
assert ['banana', 'orange', 'grape'] == fruits[:1] + fruits[1:]
def test_slice_creates_a_new_list():
fruits = ["banana", "orange", "grape"]
slice = fruits[0:2]
slice.append("guava")
assert ['banana', 'orange', 'grape'] == fruits # did this change?
assert ['banana', 'orange', 'guava'] == slice
def test_list_merge():
fruits = ["banana", "orange", "grape"]
veggies = ["beetroot", "tomato"]
all = fruits + veggies
assert ['banana', 'orange', 'grape', 'beetroot', 'tomato'] == all
assert ["banana", "orange", "grape"] == fruits
assert ["beetroot", "tomato"] == veggies
assert ["orange","grape","beetroot"] == fruits[1:] + veggies[:1]
def test_list_slice_replacement_is_inplace():
fruits = ["banana", "orange", "grape"]
fruits[1:2] = ["litchi", "guava"]
assert ['banana', 'litchi', 'guava', 'grape'] == fruits
fruits[3:] = []
assert ['banana', 'litchi', 'guava'] == fruits
fruits[:2] = []
assert ['guava'] == fruits
def test_list_common_methods():
"""
You can find methods supported by lists by entering []. (note the dot)
in the python console. the autocomplete will pop up all the available methods
on the list.
For help on a specific function like pop enter help([].pop) in console
"""
fruits = []
fruits.append("orange")
assert ["orange"] == fruits
fruits.insert(0, "banana")
assert ['banana','orange'] == fruits
fruits.extend(["litchi", "guava"])
assert ['banana', 'orange', 'litchi', 'guava'] == fruits
fruits.reverse()
assert ['guava', 'litchi', 'orange', 'banana'] == fruits
fruits.pop()
assert ['guava', 'litchi', 'orange'] == fruits
fruits.pop(0)
assert ['litchi', 'orange'] == fruits
def test_list_can_contain_lists():
fruits = ["orange", "banana"]
veggies = ["beetroot", "tomato"]
all = [fruits, veggies]
assert 2 == len(all)
assert ["orange", "banana"] == all[0]
assert ["beetroot", "tomato"] == all[1]
def test_list_can_contain_objects_of_different_types():
# note that this is rarely done in practice!
mixed = ["string", 10]
assert "string" == mixed[0]
assert 10 == mixed[1]
def test_list_sort():
numbers = [ 5, 4, 3, 8 ]
numbers.sort()
assert [3,4,5,8] == numbers
numbers.sort(reverse=True)
assert [8,5,4,3] == numbers
# if something unexpected happens see,
# https://docs.python.org/3/reference/expressions.html#comparisons
# and fix accordingly.
def test_list_membership():
numbers = [ 5, 4, 3]
assert True == (5 in numbers)
assert False == (10 in numbers)
# you will understand how this works in later lessons (the next 2 tests).
# for now understand the behavior.
def test_list_range():
# range objects can be used to generate lists of numbers of all kinds
# note that you need to pass a range object to list constructor to create the
# the list.
# print (range.__doc__)
numbers = list(range(1,5))
assert [1,2,3,4] == numbers
numbers = list(range(1, 5, 2))
assert [1,3] == numbers
def test_list_from_string():
# you can create lists from other sequences like objects like strings.
result = list("hello")
assert ['h','e','l','l','o'] == result
#Now apply what you have learnt. Type help(range) in console or read online docs
def odd_desc(count):
"""
Replace ___ with a single call to range to return a list of descending odd numbers ending with 1
For e.g if count = 2, return a list of 2 odds [3,1]. See the test below if it is not clear
"""
return list(range(count+count-1,0,-2))
def test_odd_desc():
assert [] == odd_desc(0)
assert [1] == odd_desc(1)
assert [7,5,3,1] == odd_desc(4)
assert [11,9,7,5,3,1] == odd_desc(6)
three_things_i_learnt = """
-list is mutable
-sort() and sort(reverse=True)
-insert(),append(),pop(),reverse(),extend() and '+' is for merging two lists
"""