Tiempo necesario para imprimir números


21

Resumen

Escriba un programa o función, que no tome ninguna entrada, y envíe todos los números enteros, entre -1000 y 1000 en orden ascendente, a la salida estándar, uno por línea, de esta manera:

-1000
-999
-998
-997
...

Y después de eso, debe imprimir el tiempo necesario para imprimir estos números, o el tiempo desde el inicio de la ejecución del programa en milisegundos (si es necesario, también puede contener otras cosas, por ejemplo: tiempo empleado: xxxms está bien). Puede ser un flotante o un entero (si imprime un entero, debe redondearlo al más cercano).

Código de ejemplo

using System;
using System.Diagnostics;
class P
{
    static void Main(string[] args)
    {
        Stopwatch st = Stopwatch.StartNew();
        for (int i = -1000; i <= 1000; i++)
        {
            Console.WriteLine(i);
        }
        Console.WriteLine(st.ElapsedMilliseconds);      
    }
}

Restricciones

Las lagunas estándar no están permitidas

Otras informaciones

Es el código de golf, por lo que gana la presentación más corta.


@GurupadMamadapur No, lo siento
Horváth Dávid

¿Por qué? Creo que, esencialmente, para imprimir esos números, cada declaración está involucrada desde el inicio del programa, ¿verdad?
Gurupad Mamadapur

1
@GurupadMamadapur Ok, tienes razón, editaré la pregunta en consecuencia.
Horváth Dávid

¿Puede el programa esperar una cierta cantidad de tiempo desde el principio e imprimir esa cantidad?
xnor

@xnor creo que eso cambiaría el desafío, y como ya hay muchas respuestas al desafío original, diría que no.
Horváth Dávid

Respuestas:


9

MATL , 13 bytes

1e3t_y&:!DZ`*

Pruébalo en línea!

       % Implicitly start timer
1e3    % Push 1000
       % STACK: 1000
t_     % Duplicate, negate
       % STACK: 1000, -1000
y      % Duplicate second-top number
       % STACK: 1000, -1000, 1000
&:     % Two-input range
       % STACK: 1000, [-1000, 999, ..., 1000]
!      % Transpose into column vector
       % STACK: 1000, [-1000; 999; ...; 1000]
D      % Display
       % STACK: 1000
Z`     % Push timer value, say t
       % STACK: 1000, t
*      % Multiply
       % STACK: 1000*t
       % Implicitly display

2
¡Muy agradable! Inteligente como para poner en práctica: Implicitly start timer. ¿Fue eso desde el primer día o es el resultado de un desafío anterior?
Stewie Griffin

@StewieGriffin No desde el primer día. Lo agregué el 13 de julio de 2016 , probablemente después de tener que iniciarlo explícitamente en un par de desafíos
Luis Mendo

9

Octava, 46 43 36 30 23 bytes

tic;(-1e3:1e3)',toc*1e3

Esto imprimirá:

ans =

  -1000
   -999
   -998
   -997
   -996
   -995

Si no le gusta ans =, entonces tenemos que agregar 6 bytes adicionales para disp:

tic;disp((-1e3:1e3)'),toc*1e3

Ahorró muchos bytes gracias a algunos recordatorios de rahnema1.

Explicación:

tic;                              % Starts timer
         (-1e3:1e3)'              % A vertical vector -1000 ... 1000
    disp((-1e3:1e3)'),            % Display this vector
                      toc*1e3     % Stop the timer and output the time in milliseconds

8

JavaScript, 60 bytes

(c=console).time();for(i=~1e3;i++<1e3;c.log(i));c.timeEnd();

Para obtener todos los eventos registrados, debe usar el script de la consola del desarrollador (de lo contrario, los registros se borran después de cierta cantidad de ellos).


i=~1e3guardar un byte :-)
ETHproductions

7

CJam , 18 bytes

es2001{1e3-n}/es\-

Pruébalo en línea!

Cómo funciona

es                  Push the current time (milliseconds since epoch) on the stack.
  2001{     }/      For each integer X from 0 to 2000:
       1e3-           Subtract 1000 from X.
           n          Print with a newline.
              es    Push the current time on the stack.
                \-  Swap and subtract.

7

Python 3.5, 80 77 73 bytes

import time
*map(print,range(-1000,1001)),
print(time.process_time()*1e3)

Soluciones anteriores involucradas usando timeit y time.time(), eran más grandes.

Tristemente, time.process_time() se introdujo en Python 3.3.

¡Gracias a Dennis por guardar 4 bytes!


5

Bash (+ coreutils), 41, 49, 46, 4442 bytes

EDICIONES:

  • Refactorizado para usar Bash-builtin (tiempo), para abordar las preocupaciones de precisión de @Dennis;
  • Reducido en 3 bytes, utilizando Bash 4+ |&para la redirección de stderr;
  • Ahorró 2 bytes más al reemplazar seq -1000 1000con seq -1e3 1e3(¡Gracias @Dennis!);
  • -2 bytes eliminando la barra invertida innecesaria y utilizando la precisión predeterminada (Thx @Dennis!).

Golfed

TIMEFORMAT=%R*1000;(time seq -1e3 1e3)|&bc

¡Pruébelo en línea!

Nota al margen

El uso de una utilidad "time" de coreutils, en lugar de Bash-builtin, da como resultado un 41, Solución de 35 bytes:

\time -f "%e*1000" seq -1e3 1e3|&bc

"\" está aquí para hacer que bash invoque el comando real, en lugar del comando incorporado.

Desafortunadamente, la precisión de tiempo de coreutils es solo de 1/100, lo que ha generado dudas sobre si es una solución válida.


4

R, 42 bytes

system.time(cat(-1e3:1e3,sep="\n"))[3]*1e3

Esto imprimirá

.
.
.
998
999
1000
elapsed 
     60 

Para eliminar elapsed, son necesarios dos bytes adicionales:

system.time(cat(-1e3:1e3,sep="\n"))[[3]]*1e3

4

Bash + GNU utils, 43

  • Guardado 2 bytes gracias a @Dennis
  • Guardado 5 bytes gracias a @zeppelin
c=date\ +%s%3N
s=`$c`
seq -1e3 1e3
$c-$s|bc

El datecomando da el número de segundos desde la época concatenada con los nanosegundos actuales. Este comando se ejecuta antes y después. bctoma la diferencia e imprime.

Pruébalo en línea .


Tenía la esperanza de hacer esto por 17:

time seq -1e3 1e3

Pero la salida del tiempo da más de lo que necesitamos:

real    0m0.004s
user    0m0.000s
sys 0m0.004s

1
Puede guardar dos bytes reemplazando 1000con 1e3.
Dennis

"Pero la salida del tiempo da ..." ... tal vez deberías man bash.
H Walters

1
Probablemente se puede ahorrar unos pocos bytes, mediante la captura de la fecha con ms de precisión directamente como aquí: date +%s%3N.
zepelín

4

JavaScript (ES6), 63 59 bytes

for(c=console.log,i=~1e3;i<1e3;c(++i));c(performance.now())


Agradable. Puede guardar tres bytes eliminando el espacio new (d=Date)y comenzando en -1000:for(t=new(d=Date),c=console.log,i=~1e3;i<1e3;c(++i));c(new d-t)
ETHproductions

@ETHproductions gracias :) ~1e3es un gran toque.
George Reith

1
En el fragmento, la salida es solo 952de 1000¿ por qué es eso?
Gurupad Mamadapur

@GurupadMamadapur La salida del fragmento está limitada a 50 líneas. (O más precisamente: las 50 últimas líneas.)
Arnauld

1
@IsmaelMiguel Amazing no conocía performance.now()ni la Performanceinterfaz en absoluto
George Reith

3

R, 66 bytes

x=proc.time();for(i in -1e3:1e3)cat(i,"\n");(proc.time()-x)[3]*1e3

Probablemente no sea el más corto pero funciona.


Se proc.timepuede almacenar en una variable? t=proc.time;x=t(); ...
Annan

3

Mathematica, 51 bytes

p[1*^3#]&@@AbsoluteTiming@Array[p=Print,2001,-1*^3]

Explicación

Array[p=Print,2001,-1*^3]

Almacene la Printfunción en p. Imprima los números de 2001, comenzando en -1000, incrementándose en 1.

AbsoluteTiming@ ...

Encuentra el tiempo total transcurrido en segundos.

p[1*^3#]&@@ ...

Multiplique eso por 1000 (segundos -> milisegundos) y p( Print).


¡Argh, me ganaste por 3 minutos! :) ¿Estás seguro de Timingque tampoco satisface la descripción del problema (ligeramente vaga) AbsoluteTiming?
Greg Martin el

2
@GregMartin Timinggenera el tiempo de CPU y no incluye el tiempo que tarda el front-end. Es decir. se cuenta el tiempo necesario para incrementar el contador Array, pero no se cuenta el tiempo necesario para mostrar esos números en la pantalla. Este efecto se puede ver en este simple ejemplo: Timing@Print@3da 0 segundos, pero AbsoluteTiming@Print@3no.
JungHwan Min

3

PHP, 110 70 bytes

todavía un poco largo; pero salvé 38 con la pista de @ AlexHowansky y dos más con 1e3y ~1e3.

for($t=($m=microtime)($i=~1e3);$i++<1e3;)echo"$i
";echo($m(1)-$t)*1e3;

impresiones flotantes. Corre con -r.


2
Puede pasar microtime () un valor verdadero y devolverá un flotante directamente, no tiene que agregar las cadenas.
Alex Howansky

-30% con esa pista. Desearía poder hacer diez votos a favor en tu comentario. : D
Titus

Es triste cómo PHP no tiene algo que devuelva el tiempo en milisegundos. Como Javascript tiene. No puedo sugerir mejoras. Es tan pequeño como puede ser. ¡Bien hecho!
Ismael Miguel

@IsmaelMiguel Creo que JavaScript no tiene microsegundos. :)
Titus

@Titus Lo que quise decir es que las fechas de Javascript se manejan en milisegundos, mientras que PHP solo tenía segundos o microsegundos.
Ismael Miguel

3

Powershell, 27 bytes

$1=date;-1e3..1e3;(date)-$1

Gracias a AdmBorkBork por señalar que la salida por defecto detallada es aceptable en el desafío.

Los resultados resultan como:

994
995
996
997
998
999
1000

Days              : 0
Hours             : 0
Minutes           : 0
Seconds           : 5
Milliseconds      : 679
Ticks             : 56799255
TotalDays         : 6.57398784722222E-05
TotalHours        : 0.00157775708333333
TotalMinutes      : 0.094665425
TotalSeconds      : 5.6799255
TotalMilliseconds : 5679.9255

para un resultado más contenido de solo milisegundos, use la respuesta original

$1=date;-1e3..1e3;((date)-$1).TotalMilliseconds

Ahorre tiempo antes como $ 1, imprima en stdout automáticamente, luego obtenga el tiempo entre el comienzo y el final de la ejecución.


Simplemente podría canalizar el rango a oh( Out-Host), lo que omitirá el hecho de que Measure-Commandcaptura la canalización. Ejemplo en TIO
AdmBorkBork

@AdmBorkBork el punto fue que no creo que ahorre bytes, a menos que me falte algo.
colsw

Measure-Command{-1e3..1e3|oh}es de 29 bytes. Claro, imprime cosas adicionales gracias a Measure-Command, pero el desafío establece explícitamente que está bien.
AdmBorkBork

En realidad se perdió el punto en el que puede imprimir otros datos, el creador del desafío podría necesitar decir si la salida muy detallada de Measure-Command es aceptable. también $1=date;-1e3..1e3;(date)-$1es 2 bytes más corto que la opción de medida-comando allí,
colsw

Oh cierto, jaja. Buen golf
AdmBorkBork

2

Perl 6 , 45 bytes

.put for -($_=1e3)..$_;put (now -INIT now)*$_

Intentalo

Expandido:

# print the values

.put             # print with trailing newline ( method call on 「$_」 )

for              # for each of the following
                 # ( temporarily sets 「$_」 to the value )

-(
  $_ = 1e3       # store 「Num(1000)」 in 「$_」
)
..               # inclusive Range object
$_;

# print the time elapsed

put              # print with trailing newline

(now - INIT now) # Duration object that numifies to elapsed seconds
* $_             # times 1000 to bring it to milliseconds

# The 「INIT」 phaser runs code (the second 「now」) immediately
# as the program starts.

# There is no otherwise unrelated set-up in this code so this is a
# reliable indicator of the amount of time it takes to print the values.

2

J , 22 bytes

1e3*timex'echo,.i:1e3'

Pruébalo en línea!

timexes una función integrada que ejecuta la cadena y devuelve el tiempo que tardó en evaluarla en segundos. La cadena forma el rango [-1000, 1000] usando i:, luego lo columiniza usando ,.e imprime usando el incorporado echo.


2

Pyth , 18 15 14 bytes

j}_J^T3J;*.d1J

Pruébalo aquí!

Explicación

Esto es similar a mi respuesta de Python.

    J ^ T3 Establezca J en 1000
  } _ J Lista que va de -1000 a 1000
j Únase a la lista con nuevas líneas e imprímala implícitamente
         ; *. d1J Tiempo de impresión desde la ejecución del programa en milisegundos

Ediciones :


Intenté esto, 14 bytes, no estoy seguro si funciona bien. Debe agregar una nueva línea al inicio del programa. pyth.herokuapp.com/?code=%0AM%7D_J%5ET3J%2a.d1J&debug=0
busukxuan

2

Noodel , 17 13 bytes

13 bytes

Intenté un enfoque ligeramente diferente y ahorré 4 bytes.

ƇQjȥḶGQɱ⁻Ñ€Ƈ⁻

Intentalo:)

Cómo funciona

Ƈ             # Pushes on the amount of milliseconds passed since 01/01/1970.

 Qjȥ          # Pushes 2001 onto the stack.
 Qj           # Pushes on the string "Qj"
   ȥ          # Converts the string into a number as base 98.

    ḶGQɱ⁻Ñ€   # Loops 2001 times printing -1000 to 1000.
    Ḷ         # Consumes the 2001 and loops the following code 2001 times.
     GQ       # Pushes on the string "GQ"
       ɱ      # Pushes on the current counter of the loop (i)
        ⁻     # Subtracts (i - "GQ") since i is a number, the "GQ" is converted to a number which will fail.
              # So, Noodel will treat the string as a base 98 number producing (i - 1000). 
         Ñ    # Consume what is on the top of the stack pushing it to the screen followed by a new line.
          €   # The end of the loop.

           Ƈ⁻ # Calculates the duration of execution.
           Ƈ  # Pushes on the amount of milliseconds passed since 01/01/1970.
            ⁻ # Pushes on (end - start)

17 bytes

ƇGQȥḋɲṡ×2Ḷñ⁺1€ÑƇ⁻

Intentalo:)

Cómo funciona

Ƈ                 # Pushes on the amount of milliseconds passed since 01/01/1970.

 GQȥḋɲṡ×2         # Used to create the range of numbers to be printed.
 GQ               # Pushes on the string "GQ".
   ȥ              # Converts the string into number as if it were a base 98 number. (which is 1000)
    ḋ             # Duplicates the number and pushes it onto the stack. 
     ɲ            # Since the item on top is already a number, makes the number negative (random thing I threw in at the very beginning when made the langauge and totally forgot it was there)
      ṡ           # Swaps the first two items on the stack placing 1000 on top.
       ×2         # Doubles 1000 producing... 2000

         Ḷñ⁺1€Ñ   # Prints all of the numbers from -1000 to 1000.
         Ḷ        # Consumes the 2000 to loop the following code that many times (now -1000 is on the top).
          ñ       # Prints the value on top of the stack followed by a new line.
           ⁺1     # Increment the value on top of the stack by 1.
             €    # End of the loop.
              Ñ   # Since 1000 is still not printed, this consumes 1000 and prints it followed by a new line.

               Ƈ⁻ # Calculates the number of milliseconds to execute program.
               Ƈ  # Pushes on the amount of milliseconds passed since 01/01/1970.
                ⁻ # Pushes on (end - start) in milliseconds.
                  # At the end, the top of the stack is pushed to the screen.

El fragmento utiliza los valores de -4 a 4 para no tardar tanto en completarse.

<div id="noodel" code="ƇFȥḶAɱ⁻Ñ€Ƈ⁻" input="" cols="10" rows="10"></div>

<script src="https://tkellehe.github.io/noodel/noodel-latest.js"></script>
<script src="https://tkellehe.github.io/noodel/ppcg.min.js"></script>


¿Creaste este lenguaje después o antes del desafío?
Rɪᴋᴇʀ

@EasterlyIrk, before :)
tkellehe

2

TI-Basic, 22 bytes

startTmr
For(A,-ᴇ3,ᴇ3
Disp A
End
startTmr-Ans
  • Muchos comandos están representados por tokens de 1 o 2 bytes.

  • Probado en un CSE TI-84 emulado.


2

Matlab 16 23 bytes

tic;(-1e3:1e3)'
toc*1e3

Editar: me di cuenta de que estaba violando varias de las reglas de este desafío. Eso me enseñará a leer el desafío a altas horas de la noche. Ahora también me doy cuenta de que la respuesta corregida es casi idéntica a la solución Octave, pero así es la vida.

Imprime cada elemento en la matriz espacial lineal creada -1000: 1000 (la falta de; imprime en la consola).

tic / toc registra la hora y toc imprime la hora en la consola con o sin; . Se necesita 1e3 para imprimir en milisegundos.


Muy bien, se ha editado una solución correcta.
Owen Morgan


2

8 , 61 47 bytes

Gracias a 8th_dev por una buena mejora (guardado 14 bytes)

d:msec ( . cr ) -1000 1000 loop d:msec swap - .

Esto imprimirá todos los números enteros entre -1000 y 1000 en orden ascendente y el tiempo necesario (en milisegundos) para imprimir estos números

-1000
-999
-998
-997
...
997
998
999
1000
4

1
Cabe señalar que sugerir ediciones para mejorar el código califica como "destructivo". Las sugerencias para jugar al golf se deben dar como un comentario. Haría un ping al usuario que lo hizo si pudiera, pero no puedo. meta.codegolf.stackexchange.com/q/1615/34718
mbomb007

1
Sé que lo aprobó, lo cual está bien ya que es su propia publicación, pero otros revisores en la cola de revisión deberían rechazarlo, y el usuario que sugirió la edición en primer lugar no debería haberlo hecho.
mbomb007

@ mbomb007 - Gracias por dejarme saber esto. En este caso específico verifiqué el código antes de aceptarlo, pero la próxima vez me saltearé o rechazaré este tipo de revisión.
Chaos Manor

2

Japt, 23 bytes

Hay dos soluciones equivalentes:

Oo(Ð -(A³òA³n @OpXÃ,йn
K=Ð;A³òA³n @OpXÃ;OoÐ -K

El primero básicamente hace lo siguiente:

output(-(new Date() - (1000 .range(-1000).map(X => print(X)), new Date())));

Es decir, los números se imprimen en el medio de la resta para evitar tener que almacenar el tiempo en una variable. Sin embargo, no es más corto que la ruta variable, que es básicamente:

K = new Date(); 1000 .range(-1000).map(X => print(X)); output(new Date() - K);

En la última versión de Japt (más reciente que este desafío), Kestá configurado para regresar automáticamente new Date(). Esto reduce la primera solución a 21 bytes:

Oo(K-(A³òA³n @OpXÃK)n

¡Pruébelo en línea!


1

QBIC , 34 bytes

d=timer[-z^3,z^3|?a]?z^3*(timer-d)

Utiliza la TIMERfunción QBasic , que devuelve segundos en notación decimal. Hacer que se vea bonito agrega algunos bytes.

Explicación

d=timer     Set 'd' to the current # seconds since midnight
[-z^3,z^3|  FOR -1000 to 1000  --  Note that 'z' = 10 in QBIC, and z^3 saves a byte over 1000
?a          Display the iterator
]           Close the FOR loop
    timer-d Take the current time minus the time at the start of the program -- 0.156201
?z^3*()     Multiply by a thousand and display it   156.201

1

C ++ - 261

Solo para reír, pensé en publicar una respuesta en C ++.

#include <iostream>
#include <chrono>
using namespace std::chrono; using c=std::chrono::system_clock; void p(){c::time_point n=c::now();for(int i=-1001;++i<1001;)std::cout<<i<<"\n";std::cout<<(duration_cast<milliseconds>(system_clock::now()-n)).count()<<"\n";}

Lo dejaré como ejercicio para determinar qué está haciendo y cómo llamarlo, no debería ser demasiado difícil.


1

Scala, 77 bytes

def t=System.nanoTime
val s=t
Range(-1000,1001)map println
println((t-s)/1e6)

1

ForceLang, 124

set t timer.new()
set i -1000
label 1
io.writeln set i i+1
if i=1000
 io.write math.floor 0.001.mult t.poll()
 exit()
goto 1

Nota: debe suprimir stderral ejecutar esto. Creo que el consenso sobre meta es que esto no incurre en una penalización por conteo de bytes.


1

SimpleTemplate , 92 bytes

Lo que realmente me mató fue la necesidad de registrar el tiempo.

{@callmicrotime intoX 1}{@for_ from-1000to1000}{@echol_}{@/}{@phpecho microtime(1)-$DATA[X]}

Como no hay matemáticas (todavía), esto hace las cosas bastante difíciles, lo que me obliga a escribir PHP directamente.

Sin golf:

{@call microtime into start_time true}
{@for i from -1000 to 1000 step 1}
    {@echol i}{@// echoes a newline after}
{@/}
{@php echo microtime(true) - $DATA["start_time"];}

Renuncia:

He ejecutado esto con el commit e118ae72c535b1fdbe1b80c847f52aa161854fda , del 13/01/2017.

La última confirmación fue arreglar algo que no está relacionado con el código aquí.


1

C 134 133 bytes

Gracias a @Thomas Padron-McCarthy por guardar 1 byte.

f(){clock_t s,e;s=clock();for(int i=-1000;i<1001;i++)printf("%d\n",i);e=clock();printf("%lf",((double)((e-s))/(CLOCKS_PER_SEC))*1e3);}

Versión sin golf:

void f()
{   
  clock_t s,e;

  s=clock();

  for(int i=-1000;i<1001;i++)
    printf("%d\n",i);   

  e=clock();
  printf("%f",((double)((e-s))/(CLOCKS_PER_SEC))*1e3);

 }

Puede guardar un carácter cambiando "% lf" a "% f".
Thomas Padron-McCarthy

¿Por qué no int t=time(null);... printf("%d",time(null)-t)?
Short

1

Gura , 75 bytes

t=datetime.now();println(-1000..1000);print((datetime.now()-t).usecs/1000);

1

Clojure, 94 bytes

(let[t #(System/currentTimeMillis)s(t)](doseq[n(range -1e3 1001)](println n))(println(-(t)s)))

Estoy decepcionado de cuánto tiempo pasó esto, pero supongo que nadie afirmó que Clojure era un buen idioma para jugar golf.

Solución ingenua que solo registra la hora de inicio, realiza un bucle y luego imprime la hora actual menos la hora de inicio. A menos que Clojure tenga un captador de tiempo ms de lo que me falta, no sé cómo esto podría acortarse. Tal vez algún tipo de bucle implícito?

(defn time-print []
  (let [t #(System/currentTimeMillis) ; Alias the time-getter to "t"
        start (t)] ; Record starting time
    (doseq [n (range -1000 1001)] ; Loop over the range...
      (println n)) ; ... printing the numbers

    (println (- (t) start)))) ; Then print the current time minus the starting time.
Al usar nuestro sitio, usted reconoce que ha leído y comprende nuestra Política de Cookies y Política de Privacidad.
Licensed under cc by-sa 3.0 with attribution required.