Описание задачи
Монотонная подпоследовательность представляет собой последовательность чисел , [a1, a2, ..., an]
таких , что
a1 <= a2 <= ... <= an
или a1 >= a2 >= ... >= an
. [1, 3, 3, 7, 9, 13, 13, 100]
является монотонной (неубывающей) подпоследовательностью, а также [9, 4, 4, 3, 0, -10, -12]
(эта не возрастает), но [1, 3, 6, 9, 8]
не является. Если задан список целых чисел (в любом приемлемом формате), выведите наименьшее число N
, чтобы последовательность этих целых чисел можно было разбить на N
монотонные последовательности.
Примеры
[1, 3, 7, 5, 4, 2] -> [[1, 3, 7], [5, 4, 2]] -> 2
[1, 2, 3, 4, 5, 6] -> [1, 2, 3, 4, 5, 6] -> 1
[3, 1, 5, 5, 6] -> [[3, 1], [5, 5, 6]] -> 2
[4, 6, 8, 9, 1, 6] -> [[4, 6, 8, 9], [1, 6]] -> 2
[3, 3, 3, 3] -> [[3, 3, 3, 3]] -> 1
[7] -> [[7]] -> 1
[] -> [] -> anything (you don't actually have to handle an empty list case)
[1, 3, 2, -1, 6, 9, 10, 2, 1, -12] -> [[1, 3], [2, -1], [6, 9, 10], [2, 1, -12]] -> 4
[4,4,8,8,1,4,5] -> 2
0 / undefined
, что это звучит так, как будто это должно быть либо 0, либо представление undefined
на нашем языке, но из вашего комментария к ответу Джонатана Аллана на желе это выглядит как undefined
средство anything
... Какой из них это? ? Во втором случае я бы предложил писать anything
вместоundefined