Kürzeste sortierte Hallo Welt

27

Schreiben Sie ein Programm, das keine Eingaben macht und Hello, World!auf stdout oder die nächstgelegene Alternative Ihrer Sprache druckt . Der Haken ist, dass jede Zeile in Ihrem Programm nur druckbare ASCII-Zeichen enthalten darf und in lexikografischer Reihenfolge, auch bekannt als sortiert, sein muss.

Hier sind alle 95 druckbaren ASCII-Zeichen der Reihe nach aufgeführt:

 !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~

So wäre zum Beispiel die Zeile !!A0~ungültig, weil die Aund 0nicht in Ordnung sind. Die Zeile !!0A~wäre gültig.

Jede Zeile in Ihrem Programm kann beliebig lang sein und es kann eine beliebige Anzahl von Zeilen geben. Leerzeilen gelten als sortiert. Jede der Zeilenumbrüche in Ihrem Programm muss gleich sein (kein Mischen \nund \r\n). Tabulatoren und andere nicht druckbare ASCII-Zeichen sind verboten.

Aufgrund der großen Nachfrage wurde die Gewinnbedingung geändert:
Die Einsendung mit den wenigsten Zeilen gewinnt. Tiebreaker geht zum kürzesten Programm (Zeilenumbrüche zählen als Einzelzeichen).

Es sollte nur Hello, World!ein optionaler Zeilenumbruch ausgegeben werden. Beachten Sie, dass HQ9 + ungültig ist, da es ausgegeben wirdhello, world . Ich kann ähnliche Sprachen wie HQ9 + verbieten, die ein Zeichen "Hallo, Welt!" Haben. Befehle aufgrund ihrer Trivialität.

Hinweis:

Dies ist auf jeden Fall möglich , in Unary und Lenguage , wenn auch nicht sehr prägnant.

Calvins Hobbys
quelle
7
Es ist jetzt ein bisschen spät, aber irgendwie habe ich das Gefühl, dass die wenigsten Zeilen als die wenigsten Bytes interessanter gewesen
wären
6
@ Sp3000 Wir bräuchten eine kombinierte Maßnahme, sonst würden Unary und Lenguage bedeuten, dass nur 1-Liner konkurrieren könnten.
Isaacg
@ Sp3000 Vielleicht wollte ich nur sicherstellen, dass Unary / Lenguage wahrscheinlich nicht gewinnen. Ich bin jedoch offen, es zu ändern (sorry isaacg). Stimmen Sie dem Kommentar von Upvote Sp zu, wenn Sie einverstanden sind.
Calvins Hobbys
@ Sp3000 Ich habe deinen Rat angenommen. Siehe Updates.
Calvins Hobbys
Kann die Bestellung umgekehrt werden? Zum Beispiel von links nach rechts lesen?
Ismael Miguel

Antworten:

17

Headsecks , 1 Zeile, 366 Bytes

                                                                        $(((((((((((((((((((((((((((((,000000044888<AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADIIIIIIIIIIIILPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPTXXXXXXXXXXXXXXXXXXXXXXXX\```diiiiiilqqqqqqqqtyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy|

Headsecks ist eine triviale Brainfuck-Substitution, bei der es nur auf den Codepunkt modulo 8 ankommt. Das äquivalente Brainfuck ist lediglich

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++.+++++++++++++++++++++++++++++.+++++++..+++.-------------------------------------------------------------------.------------.+++++++++++++++++++++++++++++++++++++++++++++++++++++++.++++++++++++++++++++++++.+++.------.--------.-------------------------------------------------------------------.

Zum Glück dieser naive Ansatz passt einfach . Es gibt ein gewisses Potenzial, Bytes abzubauen, aber es könnte schwierig sein.

Getestet mit diesem Python-Interpreter .


Code wird generiert

code = "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++.+++++++++++++++++++++++++++++.+++++++..+++.-------------------------------------------------------------------.------------.+++++++++++++++++++++++++++++++++++++++++++++++++++++++.++++++++++++++++++++++++.+++.------.--------.-------------------------------------------------------------------."
command_map = "+-<>.,[]"

last_point = 32
out = []

for char in code:
    curr_mod = command_map.index(char)
    last_mod = last_point % 8

    if curr_mod > last_mod:
        last_point += curr_mod - last_mod

    elif curr_mod < last_mod:
        last_point += (8 - last_mod) + curr_mod

    out.append(chr(last_point))

print("".join(out))
Sp3000
quelle
Das war schlau! +1
theonlygusti
Könnten Sie ein kürzeres BF-Programm verwenden, oder ist das Programm aus einem bestimmten Grund so aufgebaut? Ich habe mein BF-Programm ausprobiert, das ich in Ihrem Generator verwendet habe, aber die Ausgabe enthielt einen Unicode.
mbomb007
1
@ mbomb007 Das Problem bei kürzeren BF-Programmen ist, dass sogar diese naive Methode bei Codepunkt 124 endet. Ich glaube, es gibt nicht genug Spielraum, um neue Zeichen einzuführen ...
Sp3000 30.03.15
30

/// , 7 Zeilen, 22 Bytes

/
//Hello
,
 Wor
l
d
!

Eine seltene Chance für ///, wettbewerbsfähig zu sein (solange niemand mit Unary und Lenguage anfängt ...).

Der Code trifft zuerst auf a /und analysiert das

/
//

als Ersetzungsanweisung, die alle Zeilenumbrüche aus dem Rest des Programms entfernt. Danach liest das Programm nur noch

Hello, World!

die wörtlich gedruckt wird, da sie keine weiteren Schrägstriche enthält.

Martin Ender
quelle
19
Ich wusste nicht einmal, dass URLs so viele Schrägstriche hintereinander enthalten können.
Alex A.
4
@AlexA. Es hat Monate gedauert, bis diese URL funktioniert, IIRC. Wir mussten den Artikel weiter umbenennen, um Änderungen an der Serverkonfiguration und der MediaWiki-Konfiguration vornehmen zu können.
17

JavaScript (67 66 62 Zeilen, 227 269 ​​Bytes)

(Hinweis: Nur unter Firefox 36 und Safari 8 getestet, enthält kleinere ES6-Funktionen (die SetKlasse))

Z
=
!""+
(0[[]]
+
(
!!""+Set
));c
=Z[~
-22]
$=Z[
3]
$$=Z[
15]
$$$=Z[
24]
$$$$=Z[
1]
$$$$$=Z[
0]
Set
[c
+
$$$+Z[
5]
+Z[
16]
+
$$$$$+
$$$$+Z[
2]
+c
+
$$$$$+
$$$+
$$$$]
(Z[
14]
+
$$+
$+
$$$$+
$$$$$+
"(\
'H\
"+
$+
$$+
$$+
$$$+
",\
 W\
"+
$$$+
$$$$+
$$+Z[
6]
+
"\
!')\
")
()

Der obige Code bewirkt im Grunde:

alert("Hello, World!")

Offensichtlich alertist nicht sortiert. Stattdessen müssen wir die Anweisung als String generieren und "auswerten":

s = "alert('Hello, World!')";   // generate this using sorted code
eval(s)

Wie wird der String generiert? ES5 unterstützt die Fortsetzung von Zeilen

"AL\
ERT" === "ALERT"

Da der Zeichencode jedoch vor allen Kleinbuchstaben \angezeigt wird , müssen die Kleinbuchstaben mit anderen Methoden generiert werden.

Wir leihen uns hier eine Idee von JSFuck aus. Die in den Warnmeldungen enthaltenen Kleinbuchstaben sind:

t e r a o l d

All dies kann aus Zeichen von Standardobjekten extrahiert werden, die in einer bestimmten sortierten Reihenfolge ausgedrückt werden können:

t, e, r ← true      = !""
a, l    ← false     = !!""
o       ← function  = Set
d       ← undefined = 0[[]]

Wie bewerten wir den String? Sicher können wir nicht verwenden, eval(s)da es nicht sortiert ist. Alternativ könnten wir verwenden Function(s)(), aber wir können es nicht verwenden, Functionda es auch nicht sortiert ist. Ist Functionjedoch der Konstruktor aller Funktionen, was bedeutet Set.constructor === Function.

Durch Hinzufügen des Bezeichners constructorwird die Liste der Kleinbuchstaben zu:

t e r a o l d c u n s

was glücklicherweise noch generiert werden konnte von "truefalseundefinedfunction":

t, e, r, u ← true      = !""
a, l, s    ← false     = !!""
o, c, n    ← function  = Set
d          ← undefined = 0[[]]

Nach dem Prettifizieren sollte der obige Code wie folgt lauten:

// lines 1~8 defines our string containing all lowercase letters we want
Z = true + (undefined + (false + Set))
// Z = "trueundefinedfalsefunction Set() { [native code] }"

// lines 8~20 defines the variables `c`, `$` (e), `$$` (l), `$$$` (o), 
// `$$$$` (r), `$$$$$` (t)
// for the corresponding lowercase letters extracted from `Z`

// the rest calls:
Set["constructor"]("alert('Hello, World')")()
// lines 22~36 generates the "constructor" string
// lines 37~61 generates the "alert('Hello, World')" string

Update: Umbenannt E, L, O, R, , Tum verschiedene Wiederholungen von $4 Zeilen zu reduzieren.

kennytm
quelle
2
Absolut brilliant! Ich weiß nicht, ob es möglich ist, in Python dieselbe Strategiezeit zu verwenden (Groß- und Kleinschreibung beachten).
mbomb007
Sehr schön! Beachten Sie, dass geschrieben werden =Z[3*7]kann, dass =Z[~-22]nur ein Zeilenumbruch anstelle von zwei benötigt wird.
Ich und meine Katze
@ mbomb007 Ja, aber Leerzeichen sind und sie sind die ersten im ASCII-Satz ...
Harry Beadle
@meandmycat Danke! Aktualisiert.
kennytm
13

Schlaflosigkeit , 4 Zeilen, 59 Bytes

 FFFFGjnnnnooty
FLLddeejkopqyyyyy~~
(<ddjnoppppqrtu
<<Fddfj

Dieses Programm wird durch Optimierung der Zeilenzahl generiert.

10 Zeilen, 43 Bytes

(u
pt
(dppty
p~
j
<Fptt{
(otz
?o
FLu
<?FFu~

Dieses obige Programm wird durch Optimieren der Bytezahl generiert.

n̴̖̋h̴̖̋ã̷͉h̷̭̿d̷̰̀ĥ̷̳
quelle
11

Cygwin Bash, 16 Zeilen, 60 Bytes

Dies funktioniert nur aufgrund des Dateinamens, bei dem die Groß- und Kleinschreibung nicht berücksichtigt wird, und der Tatsache, dass Cygwin die Dienstprogramme ohne Berücksichtigung der Groß- und Kleinschreibung aufruft, auch wenn Sie nicht festlegen, dass der Pfad ohne Berücksichtigung der Groß- und Kleinschreibung erkannt wird.

A\
=Hello
A\
+=\
",
"Wor
A\
+=l
A\
+=d
A\
+=\
!
E\
CHO\
 $A

Beachten Sie dies ECHOam Ende.

n̴̖̋h̴̖̋ã̷͉h̷̭̿d̷̰̀ĥ̷̳
quelle
Ich bin mir nicht sicher, ob dies 17 oder 16 Zeilen sind (ganz am Ende steht eine neue Zeile), aber so oder so, das wird nichts gewinnen.
n̴̖̋h̷͉̃a̷̭̿h̷̭̿d̸̡̅ẗ̵̨́
Du hast 10 Upvotes gewonnen, das ist schon eine Menge. Diejenigen mit den meisten Stimmen (bis jetzt) ​​haben 12 Stimmen! Und die /// Lösung mit 23 positiven Stimmen.
Ismael Miguel
11

> <> , 6 Zeilen, 111 Bytes

  """""""/;;Hello
        &\o
      &++\oooo~~
"++++++++\bbbdlr
    +++++\ccccccccfooo}
    $++66\cfffffooooopr

Ich habe Probleme, eine Extralinie auszuspielen, aber auf jeden Fall bin ich froh, die 7-Linien-Methode geschlagen zu haben.

Erläuterung

> <> ist eine stapelbasierte 2D-Sprache, in der Anweisungen einzelne Zeichen sind und der Programmfluss nach oben, unten, links oder rechts erfolgen kann. Der "Befehl schaltet das Parsen von Strings um und drückt Zeichen, bis ein Closing erreicht "ist. Aufgrund der Natur von> <> gibt es jedoch kein "mehrzeiliges Parsen von Strings" wie bei CJams Strings oder Pythons Strings mit dreifachen Anführungszeichen. Dies stellte sich als schwerwiegendes Problem heraus, da das Beginnen und Beenden einer Zeile mit einem "und andere Zeichen dazwischen (z. B. "some chars") nicht zulässig sind!

Beachten Sie dies /und \spiegeln Sie den Programmablauf wider. Wir führen die erste Zeile in umgekehrter Reihenfolge aus, und die meisten Zeilen werden tatsächlich rückwärts ausgeführt!

[Line 1]

""""""              Three empty strings, push nothing
"/;;Hello  "        Push "/;;Hello  ". Note the wrapping - ><> is toroidal!
""""""              Three empty strings, push nothing

[Line 6]
66++$               Turn the top " " into "," by adding 12, then swap top two
rp                  Reverse stack and pop top 3
ooooo               Print "Hello", stack is now " ,"
fffffc              Push some 15s and a 12

[Line 5]
+++++               Sum the 15s and 12 to give 87, or "W"
}ooo                Move "W" to the back and output ", W"
fcccccccc           Push a 15 and some 12s

[Line 4]
++++++++            Sum the 15 and 12s to give 111, or "o"
"rldbbb\++++++++"   Push chars to stack
r                   Reverse stack
ld                  Push length of stack and 13, not used
bbb                 Push three 11s

[Line 3]
++&                 Sum the 11s to give 33, or "!" and put in register
~~                  Pop top two
oooo                Print "orld"

[Line 2]
&                   Put "!" from register to stack
o                   Print "!"

[Line 1]
;                   Terminate

Nebenbei bemerkt, hier ist ein amüsanter Versuch mit einem Minimum an Bytes (23 Zeilen, 47 Bytes):

v
"
!
d
l
r
o
W

,
o
l
l
e
H
"
/<
l
?
!
;
o
\^
Sp3000
quelle
2
Im zweiten Code können Sie 2 Bytes dank vertical wrap-around sparen: pastebin.com/heqCr1vJ
randomra
10

CJam, 5 4 Zeilen, 162 Bytes

"Hello
")))))))))))))))))))))))))))))))))))68S\cel
"Wor
")))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))@SX\c|

Gleiche Anzahl Leitungen wie Insomnia! (aber viel mehr Bytes)

Probieren Sie es online aus .

Erläuterung

"Hello\n"        Push "Hello" and a newline
)                Uncons the newline
)))...)))        Increment the newline into a ","
68S\             Push 68 and a space then swap, leaving 68 on top
c                Convert 68 into a char "D"
el               Lowercase "D" into "d"
"Wor\n"          Push "Wor" and a newline
)                Uncons the newline
)))...)))        Increment the newline into an "l"
@                Rotate top three elements, moving the "d" to the top
SX\              Push a space and 1 then swap, leaving the space on top
c                Convert the space (which is an array) into a char
|                Bitwise or the space (32) with 1 to give "!" (33)    

CJam druckt den Stapel anschließend automatisch aus.

Vielen Dank an @Optimizer, der mich daran erinnert hat, dass das Scfunktioniert, weil es sonst SX|fehlschlägt (es macht ein setwise oder gibt stattdessen das Array bestehend aus einem Leerzeichen und 1).

Sp3000
quelle
8

> <> (Fisch) , 5 Zeilen, viele Bytes

Der Code ist extrem lang, wenn ich sage [6535529689086686142930090 '+' signs]und [6535529689086686142930090 'd' characters]in der ersten Zeile des Codes, meine ich, dass es buchstäblich gibt6535529689086686142930090 Pluszeichen in einer Reihe gibt!

(Fügen Sie für die folgenden Zeilen die erforderlichen Präfix-Leerzeichen hinzu.)

'[6535529689086686142930090 '+' signs]^`[6535529689086686142930090 'd' characters]
                                   **,/288
                                     -/:o
                             %**288:;?\
                                   (1:\

Eine kürzere testbare Alternative, die nur druckt Hi:

'+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++^`hhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhh
                                                                                                                               **,/288
                                                                                                                                 -/:o
                                                                                                                         %**288:;?\
                                                                                                                               (1:\

Methode:

  • In der ersten Zeile erstellen wir eine riesige Zahl, die den String in base128 darstellt.
  • In den restlichen Zeilen (von unten nach oben) wird in jeder Schleife das folgende Zeichen gedruckt, bis der Wert der Ganzzahl 0 erreicht.
  • Der Schleifencode ist :1(?;:882**%:o-288**,.

(Mit dieser Methode können beliebig lange Zeichenfolgen mit mehr als 2 Zeichen gedruckt werden.)

randomra
quelle
Keine gültige Lösung; 6535529689086686142930090 ist nicht bestellt.
theonlygusti
@theonlygusti "Der Code ist extrem lang, interpretiert [6535529689086686142930090 '+' signs]und steht [6535529689086686142930090 'd' characters]buchstäblich in der ersten Codezeile." (Wenn nicht klar ist, was ich damit meine, überprüfen Sie den zweiten Teil des Codes.)
Randomra
Oh ok! Tut mir leid, ich bin dumm: PI hat es wörtlich genommen.
theonlygusti
2
Die Größe beträgt 13 YB und ist damit ungefähr 1000-mal so groß wie das Internet.
Charles
@ Charles Ich bekomme ~ 40YB einschließlich der letzteren Zeilen.
Veedrac
8

PHP (7/17 Zeilen, 36/59 Bytes):

Aufgrund der Anzahl ungültiger Antworten habe ich diese Antwort umgeschrieben.

Die Browserversion? Weg.

Aber ich habe 2 Lösungen, beide basierend auf bitwise xor( ^) von Strings in PHP.

Dies ist eine äußerst leistungsstarke Lösung! Manchmal können so viele Bytes gespart werden.

Erstens die kürzeste Antwort:

Echo
Hello
,AM^mm
,Wor
,OOO^
"#+n
";

Ich weiß, es sieht schrecklich aus, aber es funktioniert!

Der nächste hängt von Zeilenumbrüchen ab.

Ja, es werden Zeilenumbrüche verwendet ( \n/ UNIX-Stil ist erforderlich)!

Echo
Bo
.ff
.e
.
"&*]ex
fn
"^
"\n
\n
\n
\n
\n
\n
\n
",B^c
;

Die Zeilenumbrüche in diesem Fall müssen funktionieren.

Es ist nicht perfekt, aber es funktioniert!


Beide Antworten basierten auf der @ MartinBüttner - Lösung :

Echo
Hello
.
chr
(44
).
chr
(29
+3
).Wor
.l
.d
."!
";

Ein besonderer Dank geht an @ n̴̖̋h̴̖̋ã̷͉h̷̭̿d̷̰̀ĥ̷̳ , @CJDennis , @ MartinBüttner und @skagedal für die Aufdeckung all meiner Fehler und für ihre Vorschläge.

Ismael Miguel
quelle
1
Die Ausgabe im Browser ist Hello , Wor l d !. Beachten Sie die zusätzlichen Leerzeichen! Dies ist leider keine gültige Antwort.
CJ Dennis
1
Getestet in Firefox 36, IE 8, Opera 12.17 und Opera 28 (Chromium) unter Windows XP. Alle haben die Ausgabe identisch gerendert. Da eine beliebige Anzahl von Whitespace-Zeichen als einzelnes Leerzeichen dargestellt wird (mit Ausnahme von Leerzeichen usw.), wird jede neue Zeile in ein Leerzeichen umgewandelt. Es würde mich interessieren, ob ein Browser Ihre Ausgabe ohne Leerzeichen wiedergibt!
CJ Dennis
1
Netter Missbrauch der Sprache! Da die Fehler, die es technisch erzeugt, zu stderr und nicht zu stdout gehen, ist Ihr Code jetzt gültig, obwohl in meinem Fall ich viele Fehler in meinem Browser sehe! Und, unglaublich pingelig, mein PHP-Setup hat kurze Tags deaktiviert, so dass die erste Zeile auf meinem Computer <?phpungültig ist! Allerdings werde ich dir dafür vergeben! OK, gerade getestet, <?Phpwelches funktioniert, also habe ich gerade erfahren, dass beim Starttag die Groß- und Kleinschreibung nicht beachtet wird!
CJ Dennis
1
Die beiden wichtigsten Lösungen in dieser Antwort folgen nicht den Regeln. Die oberste hat als Zeile 8. "!<br- Dies ist nicht sortiert. Die zweite hat als Zeile 10: ."!- nicht sortiert.
Skagedal
1
@IsmaelMiguel Es tut mir leid, aber nein. Zeile 7 des ersten Vorschlags ist nicht sortiert. Die Zeilen 5 und 7 des zweiten Vorschlags sind nicht sortiert.
Skagedal
7

Pyth, 7 Zeilen, 23 Bytes

-
"Hello
,
 Wor
l
d
!"b

Ziemlich einfach, verwenden Sie einfach eine mehrzeilige Zeichenfolge und entfernen Sie die Zeilenumbrüche.

Probieren Sie es hier aus.

isaacg
quelle
@orlp Ich habe vor ein paar Tagen mehrzeilige Zeichenfolgen hinzugefügt, und Pyth hat seit Ewigkeiten Unterstützung für Zeilenumbrüche in der Eingabe. Dies verwendet überhaupt nicht den Multiline-Modus. Probieren Sie es auf dem Online-Compiler aus, der definitiv keinen Multiline-Modus hat.
Isaacg
2
Es ist fast das gleiche in CJam, mit der gleichen Anzahl von Bytes.
Optimierer
4

Viertens 41 Zeilen, 143 Bytes

Probieren Sie es online aus.

Darauf bin ich sehr stolz. Ich habe es ziemlich schnell rausgepeitscht, als ich herausgefunden habe, dass ich es schaffen kann, da Google nach Sprachen gesucht hat, bei denen die Groß- und Kleinschreibung nicht berücksichtigt wird, und ich kenne Forth bereits recht gut. Es kann fast definitiv verkürzt werden, sowohl Bytes als auch Zeilen. Vorschläge werden geschätzt. : D

Dieses Programm gibt im Wesentlichen den Dezimalwert jedes ASCII-Zeichens aus und druckt dann jedes einzelne aus. Ich habe versucht zu optimieren, während ich es geschrieben habe, daher ist es weniger lesbar als ich möchte.

33
99
1
+
DUp
8
+
2DUp
6
+
SWap
11
+
2OVer
SWap
8
9
*
EMit
1
+
EMit
DUp
DUp
EMit
EMit
3
+
EMit
29
3
2DUp
+
EMit
*
EMit
EMit
EMit
EMit
EMit
EMit
mbomb007
quelle
Die EmitZeilen funktionieren nicht, da i(105) kleiner als m(109) ist.
bcsb1001
Es sollte dann "EMIT" sein?
Skagedal
4

Marbelous, 9 Zeilen, 94 Bytes

3333
    @ADD
    358C
++--29\\
++--3555DE
<<<<<<>>~~
+++++446666D
++++++++../\
      ++------

Testen Sie es hier online. Using spaces for blank cellsmuss überprüft werden.

Visuelle Darstellung der Quelle:

Visuelle Darstellung der obigen Quelle

Erläuterung: Jeder hexadezimale Wert in diesem Programm bewegt sich mit jedem "Häkchen" nach unten (es sei denn, er ist aktiviert \\, in diesem Fall bewegt er sich nach rechts). ++erhöht den Wert, --verringert,~~ wendet ein Bit nicht an usw. Werte, die nach unten fallen, werden als ASCII-Zeichen gedruckt.

Zum Beispiel: Das 33in der oberen Ecke wird (((0x33 +1 +1) << 1) +1 +1 = 0x6C (l).

es1024
quelle
2

Perl, 17 Zeilen

$_
=
'pr
int
"Hello
,
 Wor
l
d
!"';s
!
!!g
;s
!.
*
!$&
!eex
nutki
quelle
2

Rebol - 15 Zeilen (51 Bytes)

PRin
AJOin
[
'Hello
Sp 
+
12
Sp
'Wor
'l
'd
Sp
+
1
]

Worte in Rebol Groß- und Kleinschreibung (zB. PRINT, PrintUndprint würden die gleiche Funktion alle nennen).

Der obige Code wurde aufgeräumt:

prin ajoin [
    'Hello  sp + 12  sp  'Wor  'l  'd  sp + 1
]

NB. spgibt das Leerzeichen zurück !

draegtun
quelle
Dein Programm ist ungültig, das {darf nicht vor Buchstaben stehen.
theonlygusti
@theonlygusti - Behoben (von 9 Zeilen auf 13 Zeilen). Die einzige Leitung, die mir Probleme bereitete, war {,}. Dies ist jetzt Sp + 12(über 3 Zeilen) das entspricht Leerzeichen + 12 (dh Komma)
draegtun
2

Unär , 1 Zeile, viele Bytes

Jeder Charakter in diesem Programm ist 0. Die Quelle ist zu lang, um sie hier einzufügen, aber sie besteht aus einer Folge dieser vielen Nullen:

327380789025192647555922325233404088310881092761595127419003295178342329930050528932118548

Dies ist die Dezimaldarstellung für diese Binärzahl:

0b1010010010010010010010010110000010010010010110000010010000010010010000010010010000010001001001001011111000010000010000011110001111001011111000000100000011011011100010010010010010010010100100010010010100000000100001011100001100010010010100011011011011011011100011011011011011011011011100000000010100

Welche wurde aus diesem BrainF *** Programm erstellt:

++++++++[>++++[>++>+++>+++>+<<<<-]>+>+>-[<]<-]>>.>---.+++++++..+++.>>.<-.<.+++.------.--------.>>+.

Sehen Sie, wie ich es generiert habe: http://ideone.com/lMT40p

mbomb007
quelle
2

Stapelverarbeitung - 39 Zeilen (202 Byte)

Ich wollte die Größe reduzieren, indem ich die verzögerte Erweiterung aktivierte, indem ich den Code innerhalb eines cmdAnrufs über den /v onSchalter ausführte, konnte aber nicht alle Karat überwinden.

@S^
ET^
LO^
C^
AL^
 EN^
ABL^
E^
DEL^
AY^
E^
DEX^
P^
ANS^
IO^
N
@S^
ET^
 0=Hello
@S^
ET^
 1=^
,^
 Wor
@S^
ET^
 2=l
@S^
ET^
 3=d
@E^
CHO^
 !^
0^
!!1^
!!2^
!!3^
!^^^
!

Ohne die Zeilenumbrüche (und Karat, um Zeilenumbrüchen zu entgehen):

@SETLOCAL ENABLEDELAYEDEXPANSION
@SET 0=Hello
@SET 1=, Wor
@SET 2=l
@SET 3=d
@ECHO !0!!1!!2!!3!^^!
unclemeat
quelle
1

Ruby, 19 Zeilen, 95 Bytes

$;=
$>
$;<<
:Hello
$;<<
44::chr
$.=
33::
-1
$;<<
$.::chr
$;<<
:Wor
$;<<
:l
$;<<
:d
$;<<
33::chr

Möglicherweise die zweithärteste Code-Einschränkung für Ruby, die ich auf dieser Site gesehen habe, nach der Monstrosität hier .

Zur Erklärung bearbeiten: Die einzige Ruby-Ausgabemethode, die sortiert wird, ist die <<Methode in STDOUT. Leider ist die Konstante für STDOUT$> und> ist höher als die meisten ASCII - Symbole, es ist also nicht wirklich möglich , ein Verfahren auf sie zu nennen. Wir brauchen eine mehrzeilige Zuweisungsanweisung, um einen besser lesbaren Variablennamen zu erhalten.$; (Semikolon ist immer noch ziemlich hoch, aber die meisten Variablen dieser Form können entweder nicht zugewiesen werden oder können nur Zeichenfolgen sein).

Symbole (:Wor usw.) sind die einfachste Möglichkeit, ein Literal zu erstellen, und ich sehe keine Möglichkeit, Zeilenumbrüche aus einer Zeichenfolge zu entfernen. Daher benötige ich mehrere print-Anweisungen. Das Leerzeichen und die Interpunktion können nicht in ein Symbol-Literal aufgenommen werden, aber zum Glück ist die chrMethode für Zahlen zulässig, sodass ich ein Zeichen aus dem ASCII-Wert abrufen kann. ::ist eine alternative Methode zum Aufrufen von Methoden. Raum ist schwierig, weil ich nicht schreiben kann 32, also subtrahiere ich 1 von 33 und ordne es einer Variablen zu.

Histokrat
quelle
0

Netzhaut, 12 Zeilen, 29 Bytes (nicht konkurrierend)

Die Sprache ist neuer als die Herausforderung.


Hello
$
,
$
 Wor
$
l
$
d
$
!

Probieren Sie es online aus

mbomb007
quelle