-
Notifications
You must be signed in to change notification settings - Fork 17
Expand file tree
/
Copy pathcan-place-flowers.py
More file actions
93 lines (78 loc) · 3.67 KB
/
can-place-flowers.py
File metadata and controls
93 lines (78 loc) · 3.67 KB
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
import unittest
class Solution(object):
def canPlaceFlowers(self, flowerbed, n):
"""
:type flowerbed: List[int]
:type n: int
:rtype: bool
"""
count = n
if count == 0:
return True
plot = 0
while plot < len(flowerbed):
if plot - 1 < 0 or not flowerbed[plot - 1]:
if plot + 1 >= len(flowerbed) or not flowerbed[plot + 1]:
if not flowerbed[plot]:
flowerbed[plot] = 1
count -= 1
if count == 0:
return True
plot += 1
else:
plot += 2
plot += 1
return False
class TestSolution(unittest.TestCase):
def setUp(self):
self.sol = Solution()
def test_empty(self):
self.assertTrue(self.sol.canPlaceFlowers([], 0))
self.assertFalse(self.sol.canPlaceFlowers([], 1))
self.assertFalse(self.sol.canPlaceFlowers([], 5))
def test_one_elem(self):
self.assertTrue(self.sol.canPlaceFlowers([0], 0))
self.assertTrue(self.sol.canPlaceFlowers([0], 1))
self.assertFalse(self.sol.canPlaceFlowers([0], 7))
self.assertTrue(self.sol.canPlaceFlowers([1], 0))
self.assertFalse(self.sol.canPlaceFlowers([1], 1))
self.assertFalse(self.sol.canPlaceFlowers([1], 6))
def test_two_elements(self):
self.assertTrue(self.sol.canPlaceFlowers([0, 0], 0))
self.assertTrue(self.sol.canPlaceFlowers([0, 0], 1))
self.assertFalse(self.sol.canPlaceFlowers([0, 0], 2))
self.assertFalse(self.sol.canPlaceFlowers([0, 0], 5))
self.assertTrue(self.sol.canPlaceFlowers([1, 0], 0))
self.assertFalse(self.sol.canPlaceFlowers([1, 0], 1))
self.assertFalse(self.sol.canPlaceFlowers([1, 0], 2))
self.assertFalse(self.sol.canPlaceFlowers([1, 0], 5))
self.assertTrue(self.sol.canPlaceFlowers([0, 1], 0))
self.assertFalse(self.sol.canPlaceFlowers([0, 1], 1))
self.assertFalse(self.sol.canPlaceFlowers([0, 1], 2))
self.assertFalse(self.sol.canPlaceFlowers([0, 1], 5))
def test_three_elements(self):
self.assertTrue(self.sol.canPlaceFlowers([0, 0, 0], 0))
self.assertTrue(self.sol.canPlaceFlowers([0, 0, 0], 1))
self.assertTrue(self.sol.canPlaceFlowers([0, 0, 0], 2))
self.assertFalse(self.sol.canPlaceFlowers([0, 0, 0], 5))
self.assertTrue(self.sol.canPlaceFlowers([1, 0, 0], 0))
self.assertTrue(self.sol.canPlaceFlowers([1, 0, 0], 1))
self.assertFalse(self.sol.canPlaceFlowers([1, 0, 0], 2))
self.assertFalse(self.sol.canPlaceFlowers([1, 0, 0], 5))
self.assertTrue(self.sol.canPlaceFlowers([0, 1, 0], 0))
self.assertFalse(self.sol.canPlaceFlowers([0, 1, 0], 1))
self.assertFalse(self.sol.canPlaceFlowers([0, 1, 0], 2))
self.assertFalse(self.sol.canPlaceFlowers([0, 1, 0], 5))
self.assertTrue(self.sol.canPlaceFlowers([0, 0, 1], 0))
self.assertTrue(self.sol.canPlaceFlowers([0, 0, 1], 1))
self.assertFalse(self.sol.canPlaceFlowers([0, 0, 1], 2))
self.assertFalse(self.sol.canPlaceFlowers([0, 0, 1], 5))
def test_three_custom1(self):
self.assertTrue(self.sol.canPlaceFlowers([1, 0, 0, 0, 1], 1))
self.assertFalse(self.sol.canPlaceFlowers([1, 0, 0, 0, 1], 2))
def test_three_custom2(self):
self.assertTrue(self.sol.canPlaceFlowers([0,1,0,1,0,1,0,0], 0))
self.assertTrue(self.sol.canPlaceFlowers([0,1,0,1,0,1,0,0], 1))
self.assertFalse(self.sol.canPlaceFlowers([0,1,0,1,0,1,0,0], 2))
if __name__ == "__main__":
unittest.main()