Sortie Lorem Ipsum de taille de code


11

Sortez la même longueur de Lorem ipsum que votre code!

Règles:

  • Le code ne peut pas être identique à la sortie
  • Aucune bibliothèque de compression
  • Le programme le plus court en deux semaines gagne
  • Aucune utilisation du réseau, la lecture de fichiers et d' autres trucs qui , avec un pourrait facilement résoudre tout problème de golf de code (avec eval, exec, etc.)

Exemple

Your code with length 25.

Production

Lorem ipsum dolor sit ame

Je ne pense pas que le texte de l'espace réservé lorem ipsum soit normalisé. Et si notre programme est plus long que l'exemple fourni? Doit-il simplement recommencer depuis le début?
M. Llama

@GigaWatt J'ai fourni un texte de plus de 1000 caractères comme lien. Si cela ne suffit pas, répétez.
randomra

Lorem ipsum dolor assis amet, élit adipiscing consectetuer. Entier nunc augue, feugiat non, egestas ut, rutrum eu, purus. Vestibulum condimentum commodo pede. Nam in 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. Eros velite éenienne, varius ac, semper 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 nous ne sommes pas autorisés à utiliser la compression / réseau intégré / langage, comment sommes-nous censés générer des informations au moins aussi longues que le programme? C'est presque comme extraire des informations de nulle part.
M. Llama

1
@GigaWatt compression (en supposant qu'elle ne doive pas être de longueur dynamique )
copie le

Réponses:


8

GolfScript (122 ou 138 octets)

Il semble y avoir une très petite ambiguïté dans les règles: que signifie exactement "sortie"? De nombreux programmes supposent que la "sortie" d'un programme n'inclut pas de retour à la ligne final, qui est là pour garantir que la ligne suivante de l'entrée shell commence sur une ligne distincte.

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

est de 122 octets et produit 122 octets de lorum ipsum et une nouvelle ligne de fin.

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

est de 138 octets et produit 138 octets de lorum ipsum sans retour à la ligne.


Ou .. vous pouvez compter la nouvelle ligne dans le cadre de la sortie et imprimer 1 octet de moins de lorem ipsum
aditsu quittez car SE est EVIL

@aditsu, j'ai également considéré cette possibilité et j'ai estimé qu'il était assez clair qu'elle compterait comme de la triche.
Peter Taylor

12

rot13 (1)

je suis surpris que personne n'ait pensé à ça avant :)

Y

et en prime, une solution perl très simple

Perl (252)

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

Belle solution perl. Une amélioration triviale de 49 octets:...ExerciTationU/;s,\S\K[A-Z], \l$&,g;print
primo

Mieux encore pour 196 octets:print'LoremIpsumDolor...NostrudExerciT'=~s,\S\K[A-Z], \l$&,gr
primo

Rot13 est-il un langage de programmation? :) Également basé sur cette idée, je modifie la longueur minimale de code pour être positive ...
randomra

2
Eh bien, la longueur de code de 1 est positive :)
aditsu quitte car SE est EVIL

Je ne pense pas que ce very simple perl solutionsoit plus.
MD XF

8

Golfscript - 161

Edit: la solution python a une longueur différente de la sienne, donc j'en ai fait une meilleure avec golfscript. C'est aussi ma première réponse 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;;]''+

Je ne sais pas comment cela est codé ici, alors voici un lien vers le fichier.


Je reçois un code de 363 octets, une sortie de 362 octets
aditsu quitte parce que SE est EVIL le

Fixé. Langues également commutées.
cardboard_box

Je vous demanderais de le poster séparément, mais à la place, je pourrais utiliser vos idées pour améliorer ma solution python :)
aditsu quitte car SE est EVIL

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 quelqu'un s'en soucie, voici une liste partielle des améliorations:
1181 -> 630 -> 549 -> 510 -> 456 -> 416 -> 381 -> 332


5

Mathematica, 8

Je fais l'hypothèse qu'une sortie visuellement identique est acceptable. J'utilise donc ce caractère à la place de l'ASCII "i" qui provoque le tri automatique des deux symboles dans le bon ordre:

іp*Lorem
Lorem іp

3

Bash, 156

Parce que l'utilisation d'une vraie "bibliothèque de compression" est interdite, je vais abuser base64de coreutils à la place. ( xxd -rpour décoder la soumission)

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.+"]..

J'ai généré le code ci-dessus en utilisant ce programme 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";

La base64 n'est-elle pas une sorte d'utilitaire de compression? En outre, je pense que vous violez "pas de lecture de fichier" - vous lisez certainement un fichier (le programme lui-même), de la même manière que le "quine" cat $0.
ugoren

1

Mathematica 47 46

Je ne sais pas si c'est du fair-play. Mathematica a le texte «complet» de Lorem ipsum dans ses données d'exemple. Ce qui suit indique simplement à Mathematica de prendre une chaîne d'une longueur particulière à partir de l'exemple intégré de Lorem Ipsum.

Modifier :

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

Original :

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

"Lorem ipsum dolor sit amet, consectetuer adipis"


1

PHP, 75 (dynamique)

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

Exemple de sortie:

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

Il n'utilise pas de compression, mais il contourne les règles. Beaucoup.
Vous pouvez ajouter des caractères parasites à la fin de l'exemple et avoir toujours la sortie correcte (jusqu'à 2k + caractères).


PHP, 59 (statique)

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

Identique à ci-dessus, mais utilise une taille fixe et sera incorrect si des caractères supplémentaires sont ajoutés.


Après la modification des règles, ma réponse n'est plus valide.
M. Llama

1

Lot Windows, 878 720

Testé sur Windows XP et Windows 7, mais devrait fonctionner pour chaque cmd avec des extensions (IIRC, Windows NT et versions ultérieures).

Doit être exécuté en utilisant CMD /V:ON /C batchfilepour activer l'extension de variable retardée, mais je préfère cela à un environnement non compatible avec le codegolf SETLOCAL EnableDelayedExpansiondans le fichier de commandes.

@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)

J'aurais été 128 si je n'avais pas eu besoin d'en faire un bon script pour que vous puissiez mesurer la sortie.

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

Comment ça marche: il n'y a que 23 caractères uniques dans le texte, donc cela peut être représenté dans un codage de 5 octets. Les caractères de la chaîne codée sont convertis en leurs nombres ASCII ( a.i.), puis chacun des nombres est transformé en leur représentation en base 2 ( #:), puis les bits sont regroupés en groupes de cinq ( _5>\,), puis chacun de ces groupes est converti à sa valeur ( #.), et ceux-ci sont utilisés comme index dans la table de recherche. ( {~).

La table de recherche avait en fait besoin d'un bricolage, car un littéral de chaîne J ne peut pas contenir \n, \rou \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

Vous pouvez compresser la table de recherche, par exemple, ('VLI., ',97}.a.)d'une certaine manière, cela ne gâche pas l'autre littéral.
randomra
En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.