Eres Tom Sawyer y tienes que pintar una cerca de 102400 m de largo. Afortunadamente, tus amigos decidieron ayudarte a cambio de varias cosas. Cada amigo pintará L metros, a partir de S con el color C . S , L son una cantidad entera de metros y 1 ≤ C ≤ 97. Aburriéndote, decides averiguar cuántos metros de cada color tienes.
Entrada
La entrada se lee desde la entrada estándar. Cada línea contiene tres números S , L , C como se describió anteriormente.
Ouput
La salida se escribe en la salida estándar. Para cada color que aparece en el cercado final, imprima el número de color y la cantidad de veces que aparece. Ordenar por colores.
Ejemplos
Entrada 0
..............
0 3 1 111...........
2 4 2 112222........
1 2 3 133222........
0 4 1 111122........
7 3 5 111122.555....
Salida 0
1 4
2 2
5 3
Entrada 1
0 100 1
50 150 2
Salida 1
1 50
2 150
Entrada 2
500 1000 1
0 2000 2
Salida 2
2 2000
Más ejemplos
Aquí hay un pequeño generador:
#include <stdio.h>
#include <assert.h>
#include <stdlib.h>
/* From http://en.wikipedia.org/wiki/Random_number_generation */
unsigned m_w;
unsigned m_z;
unsigned get_random()
{
m_z = 36969 * (m_z & 65535) + (m_z >> 16);
m_w = 18000 * (m_w & 65535) + (m_w >> 16);
return (m_z << 16) + m_w; /* 32-bit result */
}
int main(int argc, char **argv)
{
int i;
assert(argc == 2);
m_w = 0xbabecafe;
m_z = atoi(argv[1]);
i = 10;
while (i--);
get_random();
i = atoi(argv[1]);
while (i--) {
int s = (int) ((get_random() << 8) % 102397);
int l = (int) ((get_random() << 8) % (102397 - s));
int c = (int) ((get_random() << 8) % 97 + 1);
printf("%d %d %d\n", s, l, c);
}
return 0;
}
Ejecutando ejemplos:
$ ./gen 1 | ./paint
6 535
$ ./gen 10 | ./paint
28 82343
36 3476
41 1802
49 4102
82 1656
$ ./gen 100 | ./paint
2 2379
22 17357
24 4097
25 1051
34 55429
42 9028
45 9716
66 1495
71 196
85 640
97 706
$ ./gen 1000 | ./paint
16 719
26 29
28 24
33 1616
55 371
65 35
69 644
74 16
84 10891
86 36896
87 50832
89 19
$ ./gen 10000 | ./paint
3 800
6 5712
14 3022
17 16
26 1
29 18770
31 65372
37 387
44 40
49 37
50 93
55 11
68 278
70 19
71 64
72 170
77 119
78 6509
89 960
97 15
$ ./gen 100000 | ./paint
2 6
8 26
12 272
24 38576
26 1
34 1553
35 8
36 19505
43 2
45 11
46 2
47 9
49 27339
50 139
53 3109
69 11744
92 89
$ ./gen 1000000 | ./paint
1 1
3 4854
6 523
13 1
16 11
18 416
22 7
24 3920
25 96
31 10249
32 241
37 1135
45 10
57 758
62 2348
65 11
66 7422
78 6
85 13361
87 3833
88 187
91 46
93 7524
96 45436
Su programa debe ejecutarse en un tiempo razonable. Mi solución se ejecuta en unos segundos en el último ejemplo.
El código más corto gana.
Incluya el tiempo de ejecución y su salida para la última prueba.
EDITAR : Este problema no pretende ser forzado por la fuerza bruta, por lo que una solución trivial no es aceptable.
Respuestas:
Python, 221
239caracteresSe mantiene
F
como una lista desordenada de triples (inicio de ejecución, final de ejecución, color) que representan el estado actual de la cerca. Dado que la pintura aleatoria en el generador sobrepasa grandes cantidades de franjas con bastante frecuencia, esta lista nunca es demasiado larga (generalmente en el rango de 15-40).Se ejecuta en 37 segundos en el ejemplo 1M.
fuente
G+=[(a,min(b,s),d)]*(a<s)
etc. para obtener el bucle for en una líneafor C in sorted(f[2] for f in F):print C,sum(b-a for a,b,c in F if c==C)
guarda un par de caracteres en las últimas cuatro líneas y evita la necesidad de conocer el número mágico 98.sorted(set(...))
que ya no es una mejora.Haskell, 251
261269294caracteresAlgo no está del todo bien ya que lleva demasiado tiempo y se acumula ... Pero produce las respuestas correctas:
replicate
ygroup
es una forma tan eficiente de contar la pintura, y requiere menos código que la función personalizadas
max
llamarf
fuente
Perl - 148 bytes
Parece que Perl es el mejor para jugar. Fácil de codificar más corto y más rápido. ;)
código:
hora:
fuente
fuente
JavaScript, 183 caracteres, 1.3 segundos
Lamentablemente, tuve que cortar la parte stdin / out del requisito, que JavaScript no admite. En cambio, recibo la entrada de una carga de archivo
<input>
(que no cuento en mi cuenta de caracteres, aunque probablemente debería).Aquí está la versión sin golf. Es una función que toma la cadena de entrada completa ... ¡todos los 14 MB! Este es el que toma 1.3 segundos; la versión de golf dura aproximadamente el doble, ¡pero aún supera a las otras soluciones! Curiosamente, es dos veces más rápido en Firefox que en Chrome. Demostración en vivo aquí .
Y aquí está la versión de golf.
fuente