forked from keon/algorithms
-
Notifications
You must be signed in to change notification settings - Fork 0
/
is_sorted.py
44 lines (38 loc) · 1.21 KB
/
is_sorted.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
"""
Given a stack, a function is_sorted accepts a stack as a parameter and returns
true if the elements in the stack occur in ascending increasing order from
bottom, and false otherwise. That is, the smallest element should be at bottom
For example:
bottom [6, 3, 5, 1, 2, 4] top
The function should return false
bottom [1, 2, 3, 4, 5, 6] top
The function should return true
"""
import unittest
def is_sorted(stack):
storage_stack = []
for i in range(len(stack)):
if len(stack) == 0:
return True
first_val = stack.pop()
if len(stack) == 0:
return True
second_val = stack.pop()
if first_val < second_val:
return False
storage_stack.append(first_val)
storage_stack.append(second_val)
# Backup stack
for i in range(len(storage_stack)):
stack.append(storage_stack.pop())
return True
class TestSuite(unittest.TestCase):
"""
test suite for the function (above)
"""
def test_stutter(self):
# Test case: bottom [6, 3, 5, 1, 2, 4] top
self.assertFalse(is_sorted([6, 3, 5, 1, 2, 4]))
self.assertTrue(is_sorted([1, 2, 3, 4, 5, 6]))
if __name__ == "__main__":
unittest.main()