Skip to content

Commit dfb20b0

Browse files
authored
Create minimum-adjacent-swaps-to-make-a-valid-array.py
1 parent 9e009cc commit dfb20b0

File tree

1 file changed

+13
-0
lines changed

1 file changed

+13
-0
lines changed
Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
# Time: O(n)
2+
# Space: O(1)
3+
4+
# array, greedy
5+
class Solution(object):
6+
def minimumSwaps(self, nums):
7+
"""
8+
:type nums: List[int]
9+
:rtype: int
10+
"""
11+
min_idx = min(xrange(len(nums)), key=nums.__getitem__)
12+
max_idx = max(reversed(xrange(len(nums))), key=nums.__getitem__)
13+
return ((len(nums)-1)-max_idx)+min_idx-int(max_idx < min_idx)

0 commit comments

Comments
 (0)