Mathematica 66 58 51
Solução Atual
Encurtado graças a uma contribuição da Calle.
Cases[Partition[#,3,1],{a_,b_,c_}/;(a-b) (b-c)<0⧴b]&
Partition[#,3,1]
encontra os triplos.
(a-b) (b-c)<0
é verdadeira se e somente se b
estiver abaixo a
, c
ou acima a
, c
. e olha leva os sinais das diferenças. Um extremo local retornará um {-1,1}
ou {1,-1}
.
Exemplos
Cases[Partition[#, 3, 1], {a_, b_, c_} /; (a - b) (b - c) < 0 :> b] &[{1, 2, 1}]
Cases[Partition[#, 3, 1], {a_, b_, c_} /; (a - b) (b - c) < 0 :> b] &[{0, 1, 0, 1, 0}]
Cases[Partition[#, 3, 1], {a_, b_, c_} /; (a - b) (b - c) < 0 :> b] &[{}]
Cases[Partition[#, 3, 1], {a_, b_, c_} /; (a - b) (b - c) < 0 :> b] &[{9, 10, 7, 6, 9, 0, 3, 3, 1, 10}]
{2}
{1, 0, 1}
{}
{10, 6, 9, 0, 1}
Solução anterior
Este exemplo mostra todos os triplos (gerados por Partition
) e determina se o elemento do meio é menor que os dois extremos ou maior que os extremos.
Cases[Partition[#,3,1],{a_,b_,c_}/;(b<a∧b<c)∨(b>a∧b>c)⧴b]& ;
Primeira solução
Isso encontra os triplos e examina os sinais das diferenças. Um extremo local retornará um {-1,1}
ou {1,-1}
.
Cases[Partition[#,3,1],x_/;Sort@Sign@Differences@x=={-1,1}⧴x[[2]]]&
Exemplo
Cases[Partition[#,3,1],x_/;Sort@Sign@Differences@x=={-1,1}:>x[[2]]]&[{9, 10, 7, 6, 9, 0, 3, 3, 1, 10}]
{10, 6, 9, 0, 1}
Análise :
Partition[{9, 10, 7, 6, 9, 0, 3, 3, 1, 10}]
{{9, 10, 7}, {10, 7, 6}, {7, 6, 9}, {6, 9, 0}, {9, 0, 3}, {0, 3, 3}, { 3, 3, 1}, {3, 1, 10}}
%
refere-se ao resultado da respectiva linha anterior.
Differences/@ %
{{1, -3}, {-3, -1}, {-1, 3}, {3, -9}, {-9, 3}, {3, 0}, {0, -2}, {-2, 9}}
Sort@Sign@Differences@x=={-1,1}
identifica as triplas de {{9, 10, 7}, {10, 7, 6}, {7, 6, 9}, {6, 9, 0}, {9, 0, 3}, {0, 3, 3}, {3, 3, 1}, {3, 1, 10}} de modo que o sinal (-, 0, +) das diferenças consista em a -1
e a 1
. No presente caso, são eles:
{{9, 10, 7}, {7, 6, 9}, {6, 9, 0}, {9, 0, 3}, {3, 1, 10}}
Para cada um desses casos, x, x[[2]]
refere-se ao segundo termo. Esses serão todos os máximos e mínimos locais.
{10, 6, 9, 0, 1}