Lorem Ipsum in Codegröße ausgeben


11

Geben Sie die gleiche Länge von Lorem ipsum aus, die Ihr Code hat!

Regeln:

  • Code kann nicht mit Ausgabe identisch sein
  • Keine Komprimierungsbibliotheken
  • Das kürzeste Programm in zwei Wochen gewinnt
  • Keine Netzwerknutzung, Datei lesen und andere Tricks , die mit einer leicht beliebigem Code Golf Problem lösen könnten (mit eval, execetc)

Beispiel

Your code with length 25.

Ausgabe

Lorem ipsum dolor sit ame

Ich denke nicht, dass der Lorem-Ipsum-Platzhaltertext standardisiert ist. Was ist, wenn unser Programm länger als das angegebene Beispiel ist? Sollte es sich einfach noch einmal von Anfang an wiederholen?
Mr. Llama

@GigaWatt Ich habe einen über 1000 Zeichen langen Text als Link bereitgestellt. Wenn das nicht reicht, wiederholen Sie.
Randomra

Lorem ipsum dolor sitzen amet, consectetuer adipiscing elit. Integer 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 in Durchm. Nulla pellentesque. Donec vitae urna et arcu lobortis varius. Aenean Velit Eros, Varius AC, Semper Sit Amet, Lacinia Eget, Sem. Phasellus mollis nunc ein 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
Wenn wir keine integrierten Netzwerk- / Sprachfunktionen / Komprimierung verwenden dürfen, wie sollen wir dann Informationen generieren, die mindestens so lang sind wie das Programm? Das ist fast so, als würde man Informationen aus der Luft ziehen.
Herr Lama

1
@ GigaWatt Komprimierung (vorausgesetzt, es muss nicht dynamisch in der Länge sein)
Kopie

Antworten:


8

GolfScript (122 oder 138 Byte)

Es scheint eine sehr kleine Unklarheit in den Regeln zu geben: Was genau bedeutet "Ausgabe"? Viele Programme gehen davon aus, dass die "Ausgabe" eines Programms keine letzte neue Zeile enthält, um sicherzustellen, dass die nächste Zeile der Shell-Eingabe in einer separaten Zeile beginnt.

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

ist 122 Bytes und gibt 122 Bytes Lorum Ipsum und eine nachfolgende Newline aus.

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

ist 138 Bytes und erzeugt 138 Bytes Lorum Ipsum ohne nachfolgende Newline.


Oder .. Sie könnten den Zeilenumbruch als Teil der Ausgabe zählen und 1 Byte weniger Lorem
Ipsum

@aditsu, ich habe diese Möglichkeit auch in Betracht gezogen und dachte, es sei ziemlich eindeutig, dass es als Betrug gelten würde.
Peter Taylor

12

rot13 (1)

Ich bin überrascht, dass sich das noch niemand ausgedacht hat :)

Y

und als Bonus eine sehr einfache Perl-Lösung

Perl (252)

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

Schöne Perl-Lösung. Eine triviale 49-Byte-Verbesserung:...ExerciTationU/;s,\S\K[A-Z], \l$&,g;print
Primo

Besser noch für 196 Bytes:print'LoremIpsumDolor...NostrudExerciT'=~s,\S\K[A-Z], \l$&,gr
Primo

Ist rot13 eine Programmiersprache? :) Auch basierend auf dieser Idee ändere ich die minimale Codelänge so, dass sie positiv ist ...
randomra

2
Nun, die Codelänge von 1 ist positiv :)
Aditsu beendet, weil SE am

Ich glaube nicht, dass es very simple perl solutionlänger dauert.
MD XF

8

Golfscript - 161

Bearbeiten: Die Python-Lösung hat eine andere Länge als die eigene, daher habe ich mit Golfscript eine bessere gemacht. Dies ist auch meine erste Golfscript-Antwort.

[' ,.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;;]''+

Ich bin mir nicht sicher, wie dies hier codiert ist, daher hier ein Link zur Datei.


Ich bekomme 363 Bytes Code, 362 Bytes Ausgabe
Aditsu beenden, weil SE

Fest. Auch Sprachen gewechselt.
cardboard_box

Ich würde Sie bitten, es separat zu posten, aber stattdessen könnte ich Ihre Ideen verwenden, um meine Python-Lösung zu verbessern :)
Aditsu beenden, weil SE

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

Wenn es jemanden interessiert, hier eine unvollständige Liste von Verbesserungen:
1181 -> 630 -> 549 -> 510 -> 456 -> 416 -> 381 -> 332


5

Mathematica, 8

Ich gehe davon aus, dass eine visuell identische Ausgabe akzeptabel ist. Ich verwende daher dieses Zeichen anstelle von ASCII "i", wodurch die beiden Symbole automatisch in der richtigen Reihenfolge sortiert werden:

іp*Lorem
Lorem іp

3

Bash, 156

Da die Verwendung einer echten "Komprimierungsbibliothek" verboten ist, werde ich base64stattdessen Coreutils missbrauchen . ( xxd -rum die Einreichung zu dekodieren)

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

Ich habe den obigen Code mit diesem PHP-Programm generiert:

<?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";

Ist base64 nicht eine Art Komprimierungsprogramm? Ich denke auch, dass Sie gegen "kein Lesen von Dateien" verstoßen - Sie lesen sicher eine Datei (das Programm selbst), ähnlich wie das "Quine" cat $0.
Ugoren

1

Mathematica 47 46

Ich bin mir nicht sicher, ob dies ein faires Spiel ist. Mathematica hat den 'Volltext' von Lorem ipsum in seinen Beispieldaten. Im Folgenden wird Mathematica lediglich angewiesen, eine Zeichenfolge einer bestimmten Länge aus dem integrierten Beispiel von Lorem Ipsum zu übernehmen.

Bearbeiten :

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

Original :

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

"Lorem ipsum dolor sitzen amet, consectetuer adipis"


1

PHP, 75 (dynamisch)

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

Beispielausgabe:

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

Es wird keine Komprimierung verwendet, aber die Regeln werden gebogen. Viel.
Sie können am Ende des Beispiels Müllzeichen hinzufügen und trotzdem die richtige Ausgabe haben (bis zu 2k + Zeichen).


PHP, 59 (statisch)

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

Wie oben, verwendet jedoch eine feste Größe und ist falsch, wenn zusätzliche Zeichen hinzugefügt werden.


Nachdem die Regeln geändert wurden, ist meine Antwort jetzt ungültig.
Herr Lama

1

Windows Batch, 878 720

Getestet unter Windows XP und Windows 7, sollte aber für jedes cmd mit Erweiterungen (IIRC, Windows NT und höher) funktionieren.

CMD /V:ON /C batchfileMuss ausgeführt werden , um die verzögerte Variablenerweiterung zu aktivieren, aber ich bevorzuge es, wenn SETLOCAL EnableDelayedExpansiondie Batch-Datei nicht Codegolf-freundlich ist.

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

Wäre 128 gewesen, wenn ich es nicht zu einem richtigen Skript machen müsste, damit Sie die Ausgabe messen können.

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

So funktioniert es: Der Text enthält nur 23 eindeutige Zeichen, sodass dies in einer 5-Byte-Codierung dargestellt werden kann. Die Zeichen in der codierten Zeichenfolge werden in ihre ASCII-Nummern ( a.i.) konvertiert , dann wird jede der Nummern in ihre Basis-2-Darstellung ( #:) umgewandelt, dann werden die Bits in Gruppen von fünf ( _5>\,) gruppiert , und dann wird jede dieser Gruppen konvertiert auf seinen Wert ( #.), und diese werden als Index in der Nachschlagetabelle verwendet. ( {~).

Die Nachschlagetabelle musste tatsächlich etwas gebastelt werden, da ein J-String-Literal nicht enthalten kann \n, \roder \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

Sie können die Nachschlagetabelle komprimieren, z. B. ('VLI., ',97}.a.)auf eine Weise, die das andere Literal nicht durcheinander bringt.
Randomra
Durch die Nutzung unserer Website bestätigen Sie, dass Sie unsere Cookie-Richtlinie und Datenschutzrichtlinie gelesen und verstanden haben.
Licensed under cc by-sa 3.0 with attribution required.