Skip to content

Commit

Permalink
Update max-chunks-to-make-sorted-i.py
Browse files Browse the repository at this point in the history
  • Loading branch information
kamyu104 authored Jan 23, 2018
1 parent 6fe26f2 commit de3b477
Showing 1 changed file with 26 additions and 0 deletions.
26 changes: 26 additions & 0 deletions Python/max-chunks-to-make-sorted-i.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,32 @@
# Time: O(n)
# Space: O(1)

# Given an array arr that is a permutation of [0, 1, ..., arr.length - 1],
# we split the array into some number of "chunks" (partitions), and individually sort each chunk.
# After concatenating them, the result equals the sorted array.
#
# What is the most number of chunks we could have made?
#
# Example 1:
#
# Input: arr = [4,3,2,1,0]
# Output: 1
# Explanation:
# Splitting into two or more chunks will not return the required result.
# For example, splitting into [4, 3], [2, 1, 0] will result in [3, 4, 0, 1, 2], which isn't sorted.
#
# Example 2:
#
# Input: arr = [1,0,2,3,4]
# Output: 4
# Explanation:
# We can split into two chunks, such as [1, 0], [2, 3, 4].
# However, splitting into [1, 0], [2], [3], [4] is the highest number of chunks possible.
#
# Note:
# - arr will have length in range [1, 10].
# - arr[i] will be a permutation of [0, 1, ..., arr.length - 1].

class Solution(object):
def maxChunksToSorted(self, arr):
"""
Expand Down

0 comments on commit de3b477

Please sign in to comment.