Encuentra la desviación máxima

20

Este problema está "inspirado" en una pregunta que se hizo originalmente en Quora (no para golf de código). Solo quiero que sea un desafío para ustedes (y mi primer problema presentado aquí).

Dada una matriz de elementos enteros vy un entero d(suponemos que d es menor o igual a la longitud de la matriz), considere todas las secuencias de delementos consecutivos en la matriz. Para cada secuencia, calcule la diferencia entre el valor máximo y mínimo de los elementos en esa secuencia y asígnele el nombre de desviación.

Su tarea es escribir un programa o función que calcule el valor máximo entre todas las desviaciones de todas las secuencias consideradas anteriormente, y devolver o generar ese valor.

Ejemplo resuelto:

v: (6,9,4,7,4,1)
d: 3

The sequences of length 3 are:
6,9,4 with deviation 5
9,4,7 with deviation 5
4,7,4 with deviation 3
7,4,1 with deviation 6

Thus the maximal deviation is 6, so the output is 6.

Este es el código de golf, por lo que gana la respuesta más corta en bytes.

todeale
fuente

Respuestas:

14

Dyalog APL, 7 bytes

⌈/⌈/-⌊/

Pruébelo en TryAPL .

Cómo funciona

⌈/⌈/-⌊/  Dyadic chain. Left argument: d. Right argument: v

     ⌊/  Reduce v by d-wise minimum, yielding the minima of all slices of length d.
  ⌈/     Reduce v by d-wise maximum, yielding the maxima of all slices of length d.
    -    Subtract, yielding the ranges of all slices of length d.
⌈/       Take the maximum.
Dennis
fuente
5

JavaScript (ES6), 73 bytes

with(Math)(v,d)=>max(...v.map((a,i)=>max(...a=v.slice(i,i+d))-min(...a)))
Neil
fuente
+1 para TIL que puede usar withen una función lambda completa
Bassdrop Cumberwubwubwub
En realidad, Uncaught SyntaxError: Unexpected token with. ¿Puedes publicar un fragmento de trabajo?
Bassdrop Cumberwubwubwub
@BassdropCumberwubwubwub Si desea nombrar la lambda, debe colocar la asignación después de la with(Math)o usar f=eval("with(Math)(v,d)=>max(...a)))").
Neil
4

Python, 60 bytes

Ahorrando 5 bytes gracias a Neil

f=lambda v,d:v and max(max(v[:d])-min(v[:d]),f(v[1:],d))or 0

Mi primera lambda recursiva!

Uso:

print f([6,9,4,7,4,1], 3)
Karl Napf
fuente
1
Creo que puedes usarlo v and; el rango no aumentará si elimina elementos.
Neil
4

Perl, 48 bytes

Incluye +5 para -0pi

Dé el ancho después de la -iopción, dé los elementos como líneas separadas en STDIN:

perl -0pi3 -e '/(^.*\n){1,$^I}(?{\$F[abs$1-$&]})\A/m;$_=$#F'
6
9
4
7
4
1
^D

Solo el código:

/(^.*\n){1,$^I}(?{\$F[abs$1-$&]})\A/m;$_=$#F

(use un literal \npara la puntuación reclamada)

Ton Hospel
fuente
Veo una expresión regular, y luego me pierdo. 0.0 ¿Qué está pasando aquí?
Addison Crump
@VTCAKAVSMoACE Básicamente hago coincidir 1 con el ancho de líneas consecutivas. $&contendrá toda la coincidencia que se evaluará como el primer número en contexto aritmético. $1contendrá el último número. Entonces forzosamente fallo la expresión regular con \A. Por lo tanto, intentará todas las posiciones iniciales y longitudes hasta el ancho. Uso el valor absoluto de la diferencia como un índice de matriz y veo cuán grande crece la matriz. Perl no tiene incorporado, maxasí que tengo que improvisar
Ton Hospel
Eso es extremadamente inteligente. De cualquier forma que se puede poner el -0pi3 -een -0pi3e? Solo una suposición sobre una posible reducción, no uso perl (de ahí mi pregunta).
Addison Crump
@VTCAKAVSMoACE No, lamentablemente. -icome todo después de él como su valor, incluido cualquierae
Ton Hospel
¿Y supongo que eso -etiene que ir justo antes del código? Gorrón.
Addison Crump
4

R, 63 62 56 bytes

Billywob ya ha proporcionado una gran respuesta R utilizando solo las funciones básicas . Sin embargo, quería ver si era posible un enfoque alternativo, tal vez usando algunos de los amplios paquetes de R. Hay una buena función rollapplyen el zoopaquete diseñado para aplicar una función a una ventana móvil de una matriz, de modo que se adapte bien a nuestros propósitos. Usamos rollapplypara encontrar el maxde cada ventana, y lo usamos nuevamente para encontrar el minde cada ventana. Luego tomamos la diferencia entre los máximos y los minutos, lo que nos da la desviación para cada ventana, y luego devolvemos la maxde esos.

function(v,d)max((r=zoo::rollapply)(v,d,max)-r(v,d,min))
rturnbull
fuente
1
Bien, sabía que había una función para generar las subsecuencias, pero no pude encontrarla. También detrás de un proxy en el trabajo, por lo que no puedo usar ningún paquete externo.
Billywob
1
Un poco de google me informa que también hay gtools::rolling, pero ese es un byte más y no estoy familiarizado con eso. Siempre tengo dudas sobre el uso de paquetes no básicos: por un lado, se siente como hacer trampa cuando hay una solución simple; Por otro lado, creo que los paquetes (y la comunidad) son uno de los puntos fuertes de R como lenguaje.
rturnbull
3

R, 80 bytes de 77 bytes

Editar: Guardado 3 bytes gracias a @rturnbull

function(s,d)max(sapply(d:sum(1|s)-d+1,function(i)diff(range(s[i:(i+d-1)]))))
Billywob
fuente
1
Se puede reemplazar 1:(length(s)-d+1)con d:sum(1|s)-d+1.
rturnbull
@rturnbull ¡Buena captura!
Billywob
2

PowerShell v2 +, 68 bytes

param($v,$d)($v|%{($x=$v[$i..($i+++$d-1)]|sort)[-1]-$x[0]}|sort)[-1]

Solución iterativa. Se repite $v, pero en realidad solo lo estamos utilizando como contador en lugar de analizar los valores. En cada iteración, estamos cortando $vpor $i..($i+++$d-1), donde está $ipredeterminado 0. Tenemos |sortesos elementos, y almacenamos el resultado en $x. Luego tomamos el más grande [-1]y restamos el más pequeño [0]. Luego tomamos |sortesos resultados y tomamos lo más importante [-1]de eso. Ese número se deja en la tubería y la salida es implícita.

Ejemplos

PS C:\Tools\Scripts\golfing> .\find-the-maximum-deviation.ps1 @(6,9,4,7,4,1) 3
6

PS C:\Tools\Scripts\golfing> .\find-the-maximum-deviation.ps1 @(1,2,3,4,5,6) 3
2

PS C:\Tools\Scripts\golfing> .\find-the-maximum-deviation.ps1 @(7,2,3,4,5,6) 3
5
AdmBorkBork
fuente
2

05AB1E , 12 10 bytes

Utiliza la codificación CP-1252 .

Œù€{øÀ`-ÄZ

Pruébalo en línea!

Explicación

Π             # sublists of v
 ù             # of length d
  €{           # sort each
    ø          # zip
     À         # rotate left (last 2 lists will be largest and smallest)
      `        # flatten (lists with smallest and largest item will be on top)
       -       # subtract largest from smallest
        Ä      # take absolute value (as we will have negatives after the previous step)
         Z     # take the largest
Emigna
fuente
2

Java 8, 140 128

Me afeité un montón, en parte gracias a VTCAKAVSMoACE.

int l(int[]a,int d){int x=0,i=0,f,j,k;for(;i<=a.length-d;i++)for(j=i;j<i+d;j++)for(k=i;k<i+d;)x=(f=a[j]-a[k++])>x?f:x;return x;}

Sin golf

int l(int[]a,int d){
    int x=0,i=0,f,j,k;
    for(;i<=a.length-d;i++)
        for(j=i;j<i+d;j++)
            for(k=i;k<i+d;)
                x=(f=a[j]-a[k++])>x?f:x;
    return x;
}
dpa97
fuente
Te estás perdiendo un soporte final. ;)
Addison Crump
@VTCAKAVSMoACE ¡Vaya! Error de copiar y pegar :(
dpa97
1
Reducción de 5 bytes:int l(int[]a,int d){int x=0,i=0,f,j,k;for(;i<=a.length-d;i++)for(j=i;j<i+d;j++)for(k=j;k<i+d;)x=(f=a[j]-a[k++])<0?-f:f>x?f:x;return x;}
Addison Crump
@VTCAKAVSMoACE No creo que lo que tienes funcione, podría estar mal. Intente cambiar el 7 y el 1 en el caso de prueba. Sin embargo, ¡puedo usarlo para eliminar algunos de mi nueva idea!
dpa97
1
Me libré de la necesidad de abdominales (empeorando el algo en el proceso, por supuesto) al comenzar k en i también. Truco bastante ingenioso que tiene x = (f = ...) en la misma línea, gracias por eso
dpa97
2

Mathematica, 41 37 bytes

Max[MovingMap[MinMax,#,#2-1].{-1,1}]&
JungHwan Min
fuente
¿No podrías usar el producto punto con {-1,1}para evitarlo Abs?
millas
@miles ¡Gracias! Respuesta editada
JungHwan Min
@JHM Un byte guardado con Max[BlockMap[MinMax,#,#2,1].{-1,1}]&.
1

Ruby, 45 bytes

->a,d{a.each_cons(d).map{|b|b.max-b.min}.max}

Siento que esto podría ser mucho mejor.

Lee W
fuente
1

MATLAB con estadísticas y cajas de herramientas de procesamiento de imágenes, 33 bytes

@(v,d)max(range(im2col(v,[1 d])))

Esto define una función anónima. Ejemplo de uso:

>> f = @(v,d)max(range(im2col(v,[1 d])));
>> f([6,9,4,7,4,1], 3)
ans =
     6

También puede probarlo en Octave en Ideone (pero Octave, a diferencia de Matlab, requiere cargar explícitamente el paquete de imágenes).

Explicación

im2col(v,[1 d]))   % Takes overlapping blocks of size d from v, and arranges them as
                   % columns of a matrix
range(...)         % Maximum minus minimum of each column. Gives a row vector
max(...)           % Maximum of the above row vector
Luis Mendo
fuente
1

Scala, 48 bytes

(_:Seq[Int])sliding(_:Int)map(s=>s.max-s.min)max

Sin golf:

(a:Seq[Int],d:Int)=>a.sliding(d).map(s=>s.max-s.min).max

Explicación:

(_:Seq[Int])   //define a function with a seq of ints as an argument
sliding(_:Int) //get the sequences with the length of an int argument
map(s=>        //map each sequence
  s.max-s.min    //to its deviation
)max           //and take the maximum value
corvus_192
fuente
1

MATL , 10 bytes

YCS5LY)dX>

Pruébalo en línea!

Explicación

Considere las entradas [6,9,4,7,4,1], 3 como ejemplo.

       % Implicitly take the two inputs: v, d
       % STACK: [6,9,4,7,4,1], 3
YC     % Matrix of overlapping d-blocks of v
       % STACK: [6 9 4 7
                 9 4 7 4
                 4 7 4 1]
S      % Sort each column
       % STACK: [4 4 4 1
                 6 7 4 4
                 9 9 7 7]
5LY)   % Keep first and last rows
       % STACK: [4 4 4 1
                 9 9 7 7]
d      % Differences along each column
       % STACK: [5 5 3 6]
X>     % Maximum
       % STACK: 6
       % Implicitly display
Luis Mendo
fuente
1

En realidad , 13 bytes

╗╜@V`;m@M-`MM

Pruébalo en línea!

-6 bytes de la observación en la respuesta Haskell de nimi , que los cortes más cortos que dno afectan la desviación máxima.

Explicación:

╗╜@V`;m@M-`MM
╗              store d in register 0
 ╜@            push d, swap so v is on top
   V           push all slices of v whose length is in [1, d]
    `;m@M-`M   map (for each slice):
     ;m@M-       get minimum and maximum, subtract min from max
           M  get maximum of list of deviations
Mego
fuente
1

PHP, 89 87 bytes

for($i=1;$r=array_slice($argv,++$i,$argv[1]);$d=max($r)-min($r))$o=$d>$o?$d:$o;echo+$o;

No es particularmente inteligente o bonita, pero funciona. Usar como:

php -r "for($i=1;$r=array_slice($argv,++$i,$argv[1]);$d=max($r)-min($r))$o=$d>$o?$d:$o;echo+$o;" 3 6 9 4 7 1

para v= 6,9,4,7,4,1, d=3

Editar: 2 bytes guardados gracias a Jörg Hülsermann

usuario59178
fuente
echo+$o;en lugar deecho$o?:0;
Jörg Hülsermann
0

CJam , 17 bytes

q~ew{$)\(\;-}%:e>

(También q~ew:$z)\(\;.-:e> )

Pruébalo en línea!

Explicación

q~                   e# Read the two inputs. Evaluate
  ew                 e# Overlapping blocks
    {       }%       e# For each block
     $               e# Sort
      )              e# Get last element (that is, maximum)
       \(            e# Swap, get first element (minimum)
         \;          e# Swap, delete rest of the block
           -         e# Subtract (maximum minus minimum)
              :e>    e# Maximum of array
Luis Mendo
fuente
0

Java 7.159 bytes

Java = caro (sé que se puede jugar mucho más)

int c(int[]a,int d){int[]b=new int[d];int i,j,s=0;for(i=-1;i<a.length-d;){for(j=++i;j<i+d;)b[i+d-1-j]=a[j++];Arrays.sort(b);s=(j=b[d-1]-b[0])>s?j:s;}return s;}

Sin golf

static int c ( int []a , int d){
    int []b = new int[ d ];
    int i , j , s = 0 ;
    for ( i = -1 ; i < a.length - d ;) {
        for ( j = ++i ; j < i + d ;)
        b[ i + d - 1 - j ] = a[ j++ ] ;
        Arrays.sort( b ) ;
        s = ( j = b[ d - 1 ] - b[ 0 ] ) > s ? j : s ;
    }
    return s ;
    }
Nudo numérico
fuente
0

Haskell, 56 bytes

_#[]=0 
d#l|m<-take d l=max(maximum m-minimum m)$d#tail l

Ejemplo de uso: 3 # [6,9,4,7,4,1]-> 6.

Teniendo en cuenta los rangos menos dno cambia el máximo total, por lo que podemos correr take dhasta el final de la lista (es decir, también incluyen los rangos con el último d-1, d-2, ... 0elementos). La recursión se detiene con la lista vacía donde establecemos la desviación 0.

nimi
fuente
0

Raqueta 121 bytes

(let p((v v)(j 0))(let*((l(take v d))(k(-(apply max l)(apply min l)))
(j(if(> k j)k j)))(if(= d(length v))j(p(cdr v)j))))

Sin golf:

(define (f d v)
  (let loop ((v v)
             (mxdev 0))                     ; start with max deviation as 0
    (let* ((l (take v d))                   ; take initial d elements in v
           (dev (- (apply max l)            ; find deviation
                    (apply min l)))
           (mxdev (if(> dev mxdev)          ; note max deviation
                   dev
                   mxdev)))
      (if (= d (length v)) mxdev            ; if all combinations tested, print max deviation
          (loop (rest v) mxdev))            ; else test again 
      )))                                   ; with first element of list removed

Pruebas:

(f 3 '(6 9 4 7 4 1))

Salida:

6
rnso
fuente
0

q, 25 bytes

{max mmax[y;x]-mmin[y;x]}

mmaxy mminson ventanas deslizantes máximas y mínimas respectivamente

Ejemplo

q){max mmax[y;x]-mmin[y;x]}[6 9 4 7 4 1;3]
6
skeevey
fuente
0

C #, 131 bytes

aquí hay una solución detallada de linq

int c(int[]a){var x=from j in Enumerable.Range(0,a.Length-2)let p=new[]{a[j],a[j+1],a[j+2]}select p.Max()-p.Min();return x.Max();}
downrep_nation
fuente
0

C #, 163 bytes

Golfizado:

int m(List<int> v,int d){var l=new List<List<int>>();for(int i=0;i<v.Count;i++){if(v.Count-i>=d)l.Add(v.GetRange(i,d));}return l.Select(o=>o.Max()-o.Min()).Max();}

Sin golf:

public int m(List<int> v, int d)
{
  var l = new List<List<int>>();

  for (int i = 0; i < v.Count; i++)
  {
    if (v.Count - i >= d)
      l.Add(v.GetRange(i, d));
  }

  return l.Select(o => o.Max() - o.Min()).Max();
}

Prueba:

var maximumDeviation = new MaximumDeviation();
Console.WriteLine(maximumDeviation.f(new List<int> {6,9,4,7,4,1}, 3));

Salida:

6
Pete Arden
fuente
0

Pyth, 11 bytes

eSms.+Sd.:F

Explicación

eSms.+Sd.:FQ   Implicit input
          FQ   Unpack the input (v, d)
        .:     Get all subsequences of length d
  m   Sd       Sort each
   s.+         Take the sum of differences to get the deviation
eS             Get the maximum

fuente
0

Jalea , 8 bytes

ṡµṂ€ạṀ€Ṁ

Pruébalo en línea!

Utiliza el mismo algoritmo que Dyalog APL, pero lo imaginé antes de mirarlo.

Explicación:

ṡµṂ€ạṀ€Ṁ ḷ“Main link. Arguments: v d.”
ṡ        ḷ“Overlapping sublists of x of length y.”
 µ       ḷ“Start a new monadic chain.”
  Ṃ€ạṀ€  ḷ“Find the deviation of each of the elements of x.”
       Ṁ ḷ“Take the maximum of x.”

Nota: x, yse dejan, argumentos derecho, respectivamente.

Erik el Outgolfer
fuente
0

Perl 6 , 44 bytes

{$^a.rotor($^b=>1-$^b).map({.max-.min}).max}

$^ay $^bson los dos argumentos de la función, llamados vy drespectivamente en la declaración del problema. El rotormétodo devuelve la secuencia de subsecuencias vde tamaño d.

Sean
fuente
0

Clojure, 73 67 bytes

Editar: Usar en #(...)lugar de (fn[...])y en forlugar de map.

#(apply max(for[p(partition %2 1 %)](-(apply max p)(apply min p))))
NikoNyrh
fuente
0

Python 3, 80 bytes

lambda v,d:max(map(lambda g:max(g)-min(g),[v[i:i+d]for i in range(-~len(v)-d)]))
Cormac
fuente
puede usar en (max(v[i:i+d])-min(v[i:i+d])for i in range(-~len(v)-d)lugar demap(lambda g:max(g)-min(g),[v[i:i+d]for i in range(-~len(v)-d)])
Wheat Wizard