Código de salida Lorem Ipsum


11

¡Emite la misma longitud de Lorem ipsum que tu código!

Reglas:

  • El código no puede ser idéntico a la salida
  • No hay bibliotecas de compresión.
  • Programa más corto en dos semanas gana
  • No uso de la red, la lectura de archivos y otros trucos que, con una facilidad podría resolver cualquier problema de código de golf (con eval, exec, etc.)

Ejemplo

Your code with length 25.

Salida

Lorem ipsum dolor sit ame

No creo que el texto de marcador de posición lorem ipsum esté estandarizado. ¿Qué pasa si nuestro programa es más largo que el ejemplo proporcionado? ¿Debería simplemente repetir desde el principio otra vez?
Sr. Llama

@GigaWatt Proporcioné un texto de más de 1000 caracteres como enlace. Si eso no es suficiente, repite.
randomra

Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Número entero augue, feugiat non, egestas ut, rutrum eu, purus. Vestibulum condimentum commodo pede. Nam en metus eu justo commodo posuere. Nunc varius dui id nulla. Fusce porttitor pretium leo. Quisque en diam. Nulla pellentesque. Donec vitae urna et arcu lobortis varius. Aenean velit eros, varius ac, sempre sit amet, lacinia eget, sem. Phasellus mollis nunc a pede cursus fermentum. Proin et odio. Nullam turpis. Fusce eget arcu. Mauris placerat ultricies lectus. Nullam pede nisl, ullamcorper ullamcorper, hendrerit sit amet, molestie
DavidC

2
Si no se nos permite usar redes / lenguaje incorporado / compresión, ¿cómo se supone que generemos información que sea al menos tan larga como el programa? Eso es casi como sacar información de la nada.
Sr. Llama

1
Compresión @GigaWatt (suponiendo que no tiene que ser de longitud dinámica )
copie

Respuestas:


8

GolfScript (122 o 138 bytes)

Parece haber una ambigüedad muy pequeña en las reglas: ¿qué significa exactamente "salida"? Muchos programas suponen que la "salida" de un programa no incluye una nueva línea final, que está ahí para garantizar que la siguiente línea de la entrada del shell comience en una línea separada.

00000000  27 80 38 6e df 07 55 f7  a7 8f c0 42 9d dc 1e e7  |'.8n..U....B....|
00000010  7d 48 9a 88 79 03 92 c1  fb ed 8a af 51 92 52 24  |}H..y.......Q.R$|
00000020  2c b7 0b 17 d4 eb dc b0  d8 ce 8c 82 0f 94 0d 18  |,...............|
00000030  42 71 58 8a dd e6 b9 70  9b 48 74 f5 f0 70 c2 bb  |BqX....p.Ht..p..|
00000040  e0 5b 1d e1 f2 a7 29 3e  87 b4 f0 4d 3a 22 5c 71  |.[....)>...M:"\q|
00000050  55 3d d1 fd 77 12 e2 52  73 24 89 00 9b c3 e5 47  |U=..w..Rs$.....G|
00000060  0c b4 17 1a 27 32 35 36  62 61 73 65 20 39 30 62  |....'256base 90b|
00000070  61 73 65 7b 33 32 2b 7d  25 2b                    |ase{32+}%+|
0000007a

tiene 122 bytes y genera 122 bytes de lorum ipsum y una nueva línea final.

00000000  27 75 24 b6 ac 4e 36 10  aa 62 7f 2b 35 67 cc ee  |'u$..N6..b.+5g..|
00000010  c2 fa d4 9a 7a 54 96 e9  f0 0b 38 58 63 79 97 f8  |....zT....8Xcy..|
00000020  d5 7e 8a bc 4e e6 9b ee  88 ed f0 87 b5 9e 78 8c  |.~..N.........x.|
00000030  ff 4e ac 59 49 d5 71 f1  94 51 f5 4e 6a 58 57 24  |.N.YI.q..Q.NjXW$|
00000040  f6 4a 07 40 d6 06 bb a3  34 55 8d 83 aa ce d4 41  |.J.@....4U.....A|
00000050  46 04 26 c7 ef e2 f7 00  a2 61 a9 d2 40 8c 00 d9  |F.&......a..@...|
00000060  78 9a a7 53 d6 ea 85 16  23 fd c6 2c 8d a6 cb 09  |x..S....#..,....|
00000070  0a 27 32 35 36 62 61 73  65 20 39 30 62 61 73 65  |.'256base 90base|
00000080  7b 33 32 2b 7d 25 2b 3a  6e 3b                    |{32+}%+:n;|
0000008a

es de 138 bytes y produce 138 bytes de lorum ipsum sin nueva línea final.


O bien, podría contar la nueva línea como parte de la salida e imprimir 1 byte menos de lorem ipsum
cancela aditsu porque SE es MALO el

@aditsu, también consideré esa posibilidad y calculé que era bastante inequívoco que contaría como trampa.
Peter Taylor

12

rot13 (1)

Me sorprende que a nadie se le ocurriera esto antes :)

Y

y como extra, una solución perl muy simple

Perl (252)

s//LoremIpsumDolorSitAmet,ConsectetuerAdipiscingElit,SedDiamNonummyNibhEuismodTinciduntUtLaoreetDoloreMagnaAliquamEratVolutpat. UtWisiEnimAdMinimVeniam,QuisNostrudExerciTationUllamcorperSuscipitLobortisNislUtAliquipExE/;s,([^ ])([A-Z]),$1$"\l$2,g;print

Buena solución perl. Una mejora trivial de 49 bytes:...ExerciTationU/;s,\S\K[A-Z], \l$&,g;print
primo

Mejor aún para 196 bytes:print'LoremIpsumDolor...NostrudExerciT'=~s,\S\K[A-Z], \l$&,gr
primo

¿Rot13 es un lenguaje de programación? :) También en base a esta idea modifico la longitud de código mínima para que sea positiva ...
randomra

2
Bueno, la longitud del código de 1 es positiva :)
Aditsu se retiró porque SE es MALO el

No creo que sea very simple perl solutionmás.
MD XF

8

Golfscript - 161

Editar: la solución de Python genera una longitud diferente a la suya, así que hice una mejor con golfscript. Esta es también mi primera respuesta de golfscript.

[' ,.LUabcdeghilmnopqrstuvwy''zä{~4ú›Úˆ2©JfÖØélq¤öäpDÎ;bÐô(;ÆXÔZo´dZ]e§B¥×ûba(šX†Cf½ÇUÃ0~3i‰d<Ú{¡º¯ŠÛ„å4B9W}˜$ûã–'{1-}%255base{.26%@.@=\@26/.}do;;]''+

No estoy seguro de cómo se codifica esto aquí, así que aquí hay un enlace al archivo.


Estoy obteniendo un código de 363 bytes, salida de 362 bytes
Aditsu se cerró porque SE es MAL

Fijo. También cambian idiomas.
caja de cartón

Le pediría que lo publique por separado, pero en su lugar podría usar sus ideas para mejorar mi solución de Python :)
Aditsu se retiró porque SE es MAL

5

Python 2 - 332

print''.join([x,'tmoi eiidoqa  ua  lde  rsernponutsatmnci  '[ord(x)%21::21]]['.'<x<'D']for x in'LAe@1su@2lA6i?9et,;3sectetu/7d1Bc0gC<t,6e=di9:3ummy:ibhCuBmo=t0cidun?8 laAee?2lA>magna7<49Cr5 vol8p5. U?wBiCni@a=m0i@veni9, 4B:ostru=ex/ci t5i3 ull9cAp/6usc1i?lobAtB:Bl 87<41CxCa;ommo2;3se45. DuB78e@velCu@iriur>2lA 0 hendr/i?0 vulp85>')

Si a alguien le importa, aquí hay una lista parcial de mejoras:
1181 -> 630 -> 549 -> 510 -> 456 -> 416 -> 381 -> 332


5

Mathematica, 8

Supongo que una salida visualmente idéntica es aceptable. Por lo tanto, uso este carácter en lugar de ASCII "i", lo que hace que los dos símbolos se ordenen automáticamente en el orden correcto:

іp*Lorem
Lorem іp

3

Bash, 156

Debido a que está prohibido usar una "biblioteca de compresión" real, base64en su lugar abusaré de coreutils. ( xxd -rpara decodificar la presentación)

0000000: 7461 696c 202d 3120 2430 7c62 6173 6536  tail -1 $0|base6
0000010: 3420 2d77 307c 7472 2058 595a 205c 202c  4 -w0|tr XYZ \ ,
0000020: 2e0a 6578 6974 0a2e 8ade 9978 a9b2 e997  ..exit.....x....
0000030: 7689 68ad 7b22 b576 a67a d617 7289 ec79  v.h.{".v.z..r..y
0000040: cb5e b6e7 ab5d a762 a62b 1c8a 7817 7a58  .^...].b.+..x.zX
0000050: ad61 7b1e 7577 626a 65e7 a27b a69b 25e7  .a{.uwbje..{..%.
0000060: 89b8 577a e8ac 9a87 57b6 29dc 89db a7b5  ..Wz....W.).....
0000070: 7bad 5e56 a8ad e7ad 5dda 25a2 b797 99a8  {.^V....].%.....
0000080: 2769 76a5 8aab 9a99 77ab 6ad5 efa2 5bad  'iv.....w.j...[.
0000090: a5ab 595d 4b57 c22b 225d e9e2            ..Y]KW.+"]..

Generé el código anterior usando este programa PHP:

<?php

$lorem = '<text here>';

$enclorem = base64_decode( strtr( $lorem, ' ,.', 'XYZ' ) );

$prog = "tail -\$3 \$0|base64 -w0|tr XYZ \\ ,.\nexit\n$1";

for ( $i = 0, $n = strlen( $lorem ); $i < $n; $i++ ) {
    $cutlorem = substr( $lorem, 0, $i );
    for ( $j = 0, $o = strlen( $enclorem ); $j < $o; $j++ ) {
        $cutenclorem = substr( $enclorem, 0, $j );
        if ( substr( strtr( base64_encode( $cutenclorem ), 'XYZ', ' ,.' ), 0, $i )  === $cutlorem ) {
            break;
        }
    }
    $out = strtr( $prog, array(
        '$1' => $cutenclorem,
        '$2' => $i,
        '$3' => substr_count( $cutenclorem, "\n" ) + 1,
    ) );
    echo "\$i=$i strlen(\$out)=" . strlen( $out ) . "\n";
    if ( $i === strlen( $out ) ) {
        break;
    }
}

echo "\nHexdump:\n";
$p = popen( 'xxd', 'w' );
fwrite( $p, $out );
pclose( $p );

echo "\nFinal output check: ";
$tmp = tmpfile();
fwrite( $tmp, $out );
$md = stream_get_meta_data( $tmp );
ob_start();
passthru( 'bash ' . escapeshellarg( $md['uri'] ) );
$buf = rtrim( ob_get_clean() );
echo $buf === substr( $lorem, 0, strlen( $out ) ) ? 'PASS' : 'FAIL', "\n$buf\n";

¿No es base64 algún tipo de utilidad de compresión? Además, creo que usted viola "no leer archivos" - lee con certeza un archivo (el programa en sí), de manera similar a la "quine" cat $0.
ugoren

1

Mathematica 47 46

No estoy seguro si esto es juego limpio. Mathematica tiene el texto 'completo' de Lorem ipsum en sus datos de ejemplo. Lo siguiente simplemente le dice a Mathematica que tome una cadena de una longitud particular del ejemplo incorporado de Lorem Ipsum.

Editar :

e=ExampleData;e[e["Text"][[19]]]~StringTake~46

Original :

ExampleData@{"Text","LoremIpsum"}~StringTake~47

"Lorem ipsum dolor sit amet, consectetuer adipis"


1

PHP, 75 (dinámico)

<?=substr(file_get_contents('http://bit.ly/15KKxqh'),0,filesize(__FILE__));

Salida de ejemplo:

Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Maecenas porttito

No usa compresión, pero sí dobla las reglas. Mucho.
Puede agregar caracteres basura al final del ejemplo y aún tener la salida correcta (hasta 2k + caracteres).


PHP, 59 (estático)

<?=substr(file_get_contents('http://bit.ly/15KKxqh'),0,59);

Igual que el anterior, pero usa un tamaño fijo y será incorrecto si se agregan caracteres adicionales.


Después de que se modificaron las reglas, mi respuesta ahora es inválida.
Sr. Llama

1

Lote de Windows, 878 720

Probado en Windows XP y Windows 7, pero debería funcionar para cada cmd con extensiones (IIRC, Windows NT y posterior).

Tiene que ejecutarse usando CMD /V:ON /C batchfilepara activar la extensión variable retrasada, pero prefiero eso que no sea compatible con codegolf SETLOCAL EnableDelayedExpansiondentro del archivo por lotes.

@ECHO OFF
SET A=Lore2ipsu21 si0amet,6ctetu7 adip3cing4lit, sed dia2nonummy nibh4u3mod tincidun0u0laoree018magna aliqua27a0volutpat. U0w3i4ni2ad mini2veniam, qu3 nostrud4x7ci tation ullamcorp7 suscipi0lobort3 n3l u0aliquip4x4a commodo6quat. Du3 aute2vel4u2iriur81 in hendr7i0in vulputat8veli0ess8molestie6quat, vel illu21e4u feugia53 a0v7o4ros40accumsan40iusto odio dign3si2qui blandi0praesen0luptatu2zzril deleni0augu8du3 18t8feugai5i. Na2lib7 tempor cu2soluta nob34leifend option congu8nihil imp7die0doming id quod mazi2plac7a0fac7 possi2assum. Typi non haben0claritate2insitam;4s0usus legent3
FOR %%I IN ("8=e ","7=er","6= conse","5=0nulla facil3","4= e","3=is","2=m ","1=dolor","0=t ") do SET "A=!A:%%~I!"
ECHO %A%

1

J (144)

Hubiera sido 128 si no hubiera necesitado convertirlo en un script adecuado para que pueda medir la salida.

exit[stdout'utsrponmligfedcbaVLI., '{~#._5>\,#:a.i.'�F��$f����`kg�c������$NI�f!!��`�L�:����l���5l�0A����Fـ���T�X ��@g�I�`��'

Cómo funciona: solo hay 23 caracteres únicos en el texto, por lo que esto se puede representar en una codificación de 5 bytes. Los caracteres en la cadena codificada se convierten en sus números ASCII ( a.i.), luego cada uno de los números se convierte en su representación de base 2 ( #:), luego los bits se agrupan en grupos de cinco ( _5>\,), luego cada uno de estos grupos se convierte a su valor ( #.), y estos se utilizan como un índice en la tabla de búsqueda. ( {~)

La tabla de búsqueda realmente necesitaba algunos ajustes, porque un literal de cadena J no puede contener \n, \ro \0.

Hexdump:

0000000: 7865 7469 735b 6474 756f 2774 7475 7273
0000010: 6f70 6d6e 696c 6667 6465 6263 5661 494c
0000020: 2c2e 2720 7e7b 2e23 355f 5c3e 232c 613a
0000030: 692e 272e 4691 d9c3 1024 660f 0595 841d
0000040: da90 6007 676b c214 8263 81c0 b483 921a
0000050: 4e24 9549 2166 a521 60a6 4cb1 8c1d 3a03
0000060: 02d0 ca80 6cd9 9302 d800 35c5 c56c 4130
0000070: ac80 d600 00c3 0346 80d9 88ad 8001 b454
0000080: 2058 e0a5 0f40 1467 49cd 60d8 e080 0a27

Puede comprimir la tabla de búsqueda, por ejemplo, ('VLI., ',97}.a.)de alguna manera no estropea el otro literal.
randomra
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.