-
Notifications
You must be signed in to change notification settings - Fork 18
/
course_2_assessment_6.py
80 lines (54 loc) · 2.92 KB
/
course_2_assessment_6.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
# 1. Write a function, sublist, that takes in a list of numbers as the parameter. In the function, use a while loop to return a sublist of the input list. The sublist should contain the same values of the original list up until it reaches the number 5 (it should not contain the number 5).
def sublist(lst):
sublst = []
accum_var = 0
while (accum_var < len(lst)) and (lst[accum_var] != 5):
sublst.append(lst[accum_var])
accum_var += 1
return sublst
# 2. Write a function called check_nums that takes a list as its parameter, and contains a while loop that only stops once the element of the list is the number 7. What is returned is a list of all of the numbers up until it reaches 7.
def check_nums(lst):
sublst = []
accum_var = 0
while (accum_var < len(lst)) and (lst[accum_var] != 7):
sublst.append(lst[accum_var])
accum_var += 1
return sublst
# 3. Write a function, sublist, that takes in a list of strings as the parameter. In the function, use a while loop to return a sublist of the input list. The sublist should contain the same values of the original list up until it reaches the string “STOP” (it should not contain the string “STOP”).
def sublist(lst):
sublst = []
accum_var = 0
while (accum_var < len(lst)) and (lst[accum_var] != 'STOP'):
sublst.append(lst[accum_var])
accum_var += 1
return sublst
# 4. Write a function called stop_at_z that iterates through a list of strings. Using a while loop, append each string to a new list until the string that appears is “z”. The function should return the new list.
def stop_at_z(list):
i = 0
while i < len(list):
if (list[i] == 'z'):
return list[0:i]
i+=1
return list[0:i]
print(stop_at_z(['a','b','c','z']))
# 5. Below is a for loop that works. Underneath the for loop, rewrite the problem so that it does the same thing, but using a while loop instead of a for loop. Assign the accumulated total in the while loop code to the variable sum2. Once complete, sum2 should equal sum1.
sum1 = 0
lst = [65, 78, 21, 33]
for x in lst:
sum1 = sum1 + x
sum2= 0
idx = 0
while idx <len(lst):
sum2 += lst[idx]
idx += 1
sum2
# 6 .Challenge: Write a function called beginning that takes a list as input and contains a while loop that only stops once the element of the list is the string ‘bye’. What is returned is a list that contains up to the first 10 strings, regardless of where the loop stops. (i.e., if it stops on the 32nd element, the first 10 are returned. If “bye” is the 5th element, the first 4 are returned.) If you want to make this even more of a challenge, do this without slicing
def beginning(lst):
sublst = []
accum_var = 0
i = 0
while (accum_var < len(lst)) and (lst[accum_var] != 'bye' and i != 10):
sublst.append(lst[accum_var])
accum_var += 1
i += 1
return sublst