Flippign Lettesr Aroudn


33

Im Chat tippen wir oft schnell und sehen uns die Reihenfolge der Buchstaben nicht genau an , bevor wir eine Nachricht posten . Da wir faul sind, brauchen wir ein Programm, das die letzten beiden Buchstaben in unseren Wörtern automatisch vertauscht, aber da wir nicht zu spät antworten möchten, muss der Code kurz sein.

Wenn Sie es akzeptieren möchten, müssen Sie ein Programm schreiben, das die letzten beiden Buchstaben jedes Wortes in einer bestimmten Zeichenfolge umblättert (so wird das Wort Thanskzu Thanks). Ein Wort ist eine Folge von zwei oder mehr Buchstaben im englischen Alphabet, die durch ein einzelnes Leerzeichen getrennt sind.

  • Die Zeichenfolge / Liste der Zeichen, die Sie als Eingabe erhalten, enthält garantiert nur alphabetische Zeichen und Leerzeichen (ASCII [97 - 122], [65 - 90] und 32).

  • Sie können Eingaben und Ausgaben mit jeder Standardmethode und in jeder Programmiersprache vornehmen. Beachten Sie dabei, dass diese Lücken standardmäßig verboten sind.

  • Die Ausgabe kann ein nachgestelltes Leerzeichen und / oder eine nachgestellte Newline enthalten.

  • Die Eingabe enthält immer nur Wörter (und das entsprechende Leerzeichen) und besteht aus mindestens einem Wort.

Das ist Code-Golf, also gewinnt die kürzeste Einsendung (in Bytes) in jeder Sprache!

Testfälle

Beachten Sie, dass die Zeichenfolgen aus Gründen der Lesbarkeit in Anführungszeichen gesetzt sind.

Eingabe -> Ausgabe

"Thansk" -> "Danke"
"Youer welcoem" -> "Du bist willkommen"
"Das ist ein Apfel" -> "Thsi si na appel"
"Flippign Lettesr Aroudn" -> "Briefe umdrehen"
"DER ANDERE CHALLENEG MIT AUSTAUSCH VON BRIEFEN" -> "DER ANDERE CHALLENGE MIT AUSTAUSCH VON BRIEFEN"

Zur Vereinfachung der Testsuite sind hier die Eingänge und die entsprechenden Ausgänge separat aufgeführt:

Thansk
Herzlich willkommen
Das ist ein Apfel
Flippign Lettesr Aroudn
Der alte chaleNeg mit austauschbaren Briefen
Vielen Dank
Bitte
Dies ist ein Appell
Briefe umdrehen
teH odD chALleNge mit getauschten Briefen

Vielen Dank an DJMcMayhem für den Titel. Dies war ursprünglich ein CMC .


Dürfen wir eine Reihe von Wörtern ausgeben?
Shaggy

@ Shaggy Nein, die Ausgabe muss eine Zeichenfolge sein (oder standardmäßig eine Liste von Zeichen)
Mr. Xcoder

Dürfen wir für jede Eingabe ein Leerzeichen anfordern?
FlipTack

@FlipTack In der ursprünglichen Version war dies zulässig , aber ich habe diese Regel entfernt, bevor eine der Antworten veröffentlicht wurde, die diese verwenden würden. (Zum Teil, weil mir einige Benutzer im Chat gesagt haben, dass ich das sonst zu einfach mache und ich stimme ihnen zu). Nein, das ist nicht erlaubt.
Mr. Xcoder

1
@ Fabian Ein Wort ist eine Folge von zwei oder mehr Buchstaben
Mr. Xcoder

Antworten:


16

V , 4,5 Bytes

òeXp

Probieren Sie es online!

|| bezeichnet den Cursor

Der Puffer beginnt mit |w|ord and more wordsund der Cursor steht auf dem ersten Zeichen.

Rekursiv ò

Gehe auf den ePunkt

wor|d| and more words

Entfernen Sie Xdas Zeichen links vom Cursor

wo|d| and more words

paste es über das nächste Zeichen

wod|r| and more words

Implizites Ende ò, wiederholen Sie den gleichen Vorgang für andere Wörter, bis das Ende des Puffers erreicht ist


2
Die richtige Sprache für die Aufgabe :)
DJMcMayhem

Meinst du "wiederholt" statt "rekursiv"?
NieDzejkob

@NieDzejkob Im V-Wiki wird das Wort "rekursiv" verwendet, um den òBefehl github.com/DJMcMayhem/V/wiki/Normal-Mode-Commands
Kritixi Lithos

10

Gelee , 7 Bytes

Ḳœ?@€2K

Eine monadische Verknüpfung, die Listen von Zeichen aufnimmt und zurückgibt

Probieren Sie es online!

Wie?

Ḳœ?@€2K - Link: list of characters
Ḳ       - split at spaces
     2  - literal two
    €   - for €ach:
   @    -   with sw@pped arguments:
 œ?     -     nth permutation (the 2nd permutation has the rightmost elements swapped)
      K - join with spaces

Das ist ein netter Missbrauch von Permutationen. Alternative
Mr. Xcoder

@ Mr.Xcoder Ḳ2œ?ЀKfunktioniert auch und benutzt einen einzigen Quick.
Dennis

7

Brain-Flak , 122 Bytes

{(({})[((((()()){}){}){}){}])((){[()](<{}>)}{}){{}<>(({}({}))[({}[{}])])(<>)}{}({}<>)<>}<>(({}({}))[({}[{}])]){({}<>)<>}<>

Probieren Sie es online!

Die schlechteste Sprache für den Job :)

Lesbar Etwas besser lesbare Version:

{
    (({})[((((()()){}){}){}){}])((){[()](<{}>)}{})

    {
        {}
        <>

        (({}({}))[({}[{}])])

        (<>)
    }
    {}

    ({}<>)<>

}<>

(({}({}))[({}[{}])])

{

    ({}<>)
    <>
}<>

Ich kann nicht glauben, dass dies länger ist als die Brainfuck-Version ...
Pureferret

@pureferret Brain-Flak ist in der Regel länger als Brainfuck. Meistens benötigt es zwei Bytes pro primitivem Befehl, während Brain-Flak zwei benötigt.
DJMcMayhem



6

Python 3 , 50 Bytes

print(*(w[:-2]+w[:-3:-1]for w in input().split()))

Probieren Sie es online!

Diese Antwort missbraucht das Druckverhalten von Python 3: Mehrere Argumente werden mit einem Leerzeichen dazwischen gedruckt. Natürlich können wir nicht einfach mehrere Argumente angeben, da wir nicht wissen, wie viele Wörter in der Eingabe enthalten sein werden. Also benutzen wir den splat Operator . Grundsätzlich gilt

print(*[a,b,c])

ist genau das gleiche wie

print(a,b,c)

Missbrauch macht ein volles Programm kürzer als eine Funktion / Lambda, die wir verwenden müssten, ' '.joinoder ähnliches.


Sieht aus wie Python 2 2 Bytes durch Schreiben speichert for w in input().split():print w[:-2]+w[:-3:-1],. In Python 3 würde das Extrahieren der letzten beiden Zeichen gut funktionieren, mit der print(*(''.join(a)+c+b for*a,b,c in input().split()))Ausnahme, dass adies in einen String umgewandelt werden muss.
xnor

5

Matlab (R2016b), 51 50 Bytes

Gespeichert 49 50 (!) Bytes dank @Giuseppe.

function s(a),regexprep(a,'(\w)(\w)( |$)','$2$1 ')

Und meine bisherige Antwort:

Matlab (R2016b), 100 Byte

(Nur zum Spaß: P)

function s(a),a=regexp(a,' ','split');for i=1:length(a),fprintf('%s ',a{i}([1:end-2 end end-1])),end

Erläuterung:

function s(a) % Defining as a function...
a=regexp(a,' ','split'); % Splits the input string at the spaces
for i=1:length(a) % Loops through each word
    fprintf('%s ',a{i}([1:end-2 end end-1])) % And prints everything with the last two characters swapped.
end

1
Ein-Zeichen-Wörter dürfen nicht vorkommen, da ein Wort aus mindestens zwei Zeichen besteht.
Giuseppe

würde regexprephier arbeiten? So etwas wie regexprep(a,'(\w*)(\w)(\w)','\1\3\2')?
Giuseppe

D = Dies. War. Epos! Ich denke, Sie sollten diese Antwort posten, da sie sich völlig von meiner unterscheidet. Das Einzige ist, dass Matlab auf die Übereinstimmungen verweist $1und nicht \1, so wäre es regexprep(a,'(\w*)(\w)(\w)','$1$3$2').
Thiago Oleinik

1
Sie sollten es als separate Antwort / in dieser Antwort posten; Es ist immer gut zu sehen, ob ein Regex bei einer String-Herausforderung hilft oder nicht! Außerdem verstehe ich die Regex-Engine von MATLAB eindeutig nicht, daher wäre es für mich nicht fair, das zu würdigen.
Giuseppe

1
function s(a),regexprep(a,'(\w)(\w)( |$)','$2$1 ')ist noch ein Byte kürzer!
Giuseppe


4

Prolog (SWI) , 60 Bytes

[A,B]+[B,A].
[A,B,32|U]+[B,A,32|Y]:-U+Y,!.
[A|U]+[A|Y]:-U+Y.

Probieren Sie es online!

Erläuterung

Zuerst definieren wir den Basisfall:

p([A,B],[B,A]).

Dies bedeutet, dass die letzten beiden Buchstaben immer vertauscht werden.

Dann definieren wir, was passiert, wenn wir uns direkt neben einem Leerzeichen befinden:

p([A,B,32|U],[B,A,32|Y]):-p(U,Y),!.

Zwei Zeichenfolgen stimmen überein, wenn unmittelbar vor einem Leerzeichen die Buchstaben vor dem Leerzeichen vertauscht sind, und der Rest, wenn die Zeichenfolgen übereinstimmen. Wir verwenden dann !zu schneiden.

Unser letzter Fall ist, wenn wir nicht neben einem Leerzeichen stehen, müssen die ersten beiden Buchstaben übereinstimmen.

p([A|U],[A|Y]):-p(U,Y).

4

Wolfram-Sprache , 117 Bytes

StringReplace[RegularExpression["\\b[[:alpha:]]{2,}\\b"]:>StringDrop[StringInsert["$0",StringTake["$0",{-1}],-3],-1]]

Probieren Sie es online!

Auf die Teststrings angewendet.

StringReplace[
  RegularExpression["\\b[[:alpha:]]{2,}\\b"] :> 
   StringDrop[StringInsert["$0", StringTake["$0", {-1}], -3], -1]] /@
 {"Thansk", "Youer welcoem", "This is an apple", 
  "Flippign Lettesr Aroudn", "tHe oDd chALlEneg wiht swappde lettesR"} // Column
Thanks
Youre welcome
Thsi si na appel
Flipping Letters Around
teH odD chALlEnge with swapped letteRs

4
Willkommen bei PPCG!
Steadybox

@Steadybox Danke.
Edmund

4

R , 111 51 41 Bytes

Mit freundlicher Genehmigung von @ Giuseppe, einem Regex-Ansatz, der meine alte Methode aus dem Wasser bläst.

cat(gsub("(.)(.)\\b",'\\2\\1',scan(,"")))

1
Regex ist hier viel effizienter: Probieren Sie es online aus!
Giuseppe

(nicht, dass ich den Mut, einen reinen String-Manipulations-Ansatz in R zu machen, nicht schätze)
Giuseppe


@ Giuseppe Wow, gute Arbeit! Ich habe sie in meine Antwort eingearbeitet. Wenn Sie es jedoch vorziehen, eine eigene Antwort zu erstellen, fahren Sie fort!
Turnbull

1
Nein, mach dir keine Sorgen. Ich habe weitere 10 Byte Golf gespielt : Portierung eines anderen Regex-Ansatzes und 70 Byte Ihres alten Ansatzes
Giuseppe

4

APL (Dyalog Classic) , 28 Byte

1↓∊((¯2↓⊢),2↑⌽)¨' '(,⊂⍨⊣=,)⍞

⎕MLund ⎕IOsind beide 1,

Probieren Sie es online!

Erläuterung

  • ... (,⊂⍨⊣=,) ... Teilen (unter Beibehaltung der Rahmen und Anhängen eines Rahmens an den Anfang) ...
  • ... ⍞ ... die Eingabe ...
  • ... ' ' ... ... in Räumen.
  • ... ( ... )¨ ... Dann zu jedem Element davon:
    • ... , ... Verketten ...
    • ... (¯2↓⊢) ... ... jeder Gegenstand außer den letzten beiden ...
    • ... 2↑⌽ ... ... mit der Umkehrung der letzten beiden Elemente.
  • 1↓∊ ... Geben Sie zum Schluss alle Elemente außer dem ersten Element des reduzierten Ergebnisses zurück.

kehre alle bis auf den ersten zurück
Adám



3

J , 20 - 19 - 11 Bytes

Dank an @Bolce Bussiere

1&A.&.>&.;:

Probieren Sie es online!

       &.;:      on words
    &.>          on each
  A.             apply the permutation
1&               number 1, swap the last two elements

1
13 Bytes mit(1&A.&.>)&.;:
Bolce Bussiere

@ BolceBussiere perfekt
FrownyFrog

Könnten Sie eine Erklärung hinzufügen? Ich frage mich, ob ich es nach K portieren kann, um die peinliche Byteanzahl meiner Lösung zu verringern.
Streetster

3

Alice , 24 Bytes

/0RR'.%$1\' o
\ix*o ne@/

Probieren Sie es online!

Erläuterung

/...\' o
\.../

Dies bildet eine Schleife, in der der Schleifenkörper ein lineares Ordinal-Snippet ist und ' ozwischen jeweils zwei Schleifeniterationen im Kardinal-Modus ausgeführt wird. Letzteres druckt nur ein Leerzeichen.

Wenn Sie die Zick-Zack-Struktur des Ordinal-Codes aufklappen, sieht der Körper der linearen Schleife tatsächlich so aus:

iR*' %e10xRo.n$@

Aufschlüsselung:

i     Read all input. On subsequent iterations, this will push an empty string.
R     Reverse.
*     Join. On the first iteration, this joins the input to an implicit empty string,
      which does nothing. On subsequent iterations, it will join the empty string to
      the word on top of the string, thereby getting rid of the empty string.
' %   Split around spaces. On the first iteration, this will split the input
      into individual words. On subsequent iterations, this does nothing.
e10   Push "10".
x     Use this to permute the (reversed) word on top of the stack. In
      particular, the word is rearranged with the same permutation that is
      required to sort the string "10", which means the first two letters
      get swapped (which correspond to the last two letters of the actual
      word).
R     Reverse the swapped word.
o     Print it.
.n$@  If there are no words left on the stack, terminate the program.

Ich habe gerade bemerkt, dass der Buchstabentausch in drei Bytes ( h~Z) statt in vier Bytes ( ) erfolgen kann e10x, aber ich sehe keine Möglichkeit, das Layout so anzupassen, dass insgesamt tatsächlich ein Byte gespeichert wird.
Martin Ender

2

Brainfuck , 109 100 Bytes

Bearbeiten: Es müssen keine Wörter mit einem Buchstaben behandelt werden

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

Probieren Sie es online!

Druckt ein Leerzeichen nach

Wie es funktioniert

,[>++++[-<-------->],] Puts input on the tape and subtracts 32 from each character
                       This separates each word

>+[- Start the loop
   <[>++++[<++++++++>-]<[->>+<<]<] Add 32 to each letter of the word
                                   Skip this on the first iteration for the last word

   <<[->>+<<]>[[-<+>]>] Swaps the last two letters of the word
   <<[>+>+>]- If there is another word to the left continue loop
              Also set up to add a space to the end of the word
 <] End loop
 >>>>>>>[.>] Print the modified string

Vorherige Version, 109 Bytes

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

Probieren Sie es online!



1

PHP , 119 107 Bytes

Edit: danke an totalhuman

<?php foreach(explode(" ",trim(fgets(STDIN)))as$w)echo substr($w,0,strlen($w)-2).strrev(substr($w,-2))," ";

Probieren Sie es online!


1
Können Sie $wordkeinen einzelnen Variablennamen erstellen?
Totalhuman

@totallyhuman Yup! Ich habe die Vollversion geschrieben und dann komprimiert, aber das merkte ich nicht. Danke.
Zerquix18

PHP Open Tags können in der Antwort weggelassen werden, wodurch Sie 6 Bytes sparen.
Daniel W.

Ich frage mich, ob fgets(STDIN)auch weggelassen oder ersetzt werden kann $x, da nicht alle Antworten die Eingabe zu ihren Antworten zählen
Daniel W.

trim()sollte unnötig sein.
Titus

1

Haskell , 41 Bytes

foldr(%)" "
a%(b:' ':r)=b:a:' ':r
a%s=a:s

Probieren Sie es online!

Ausgaben mit einem Leerzeichen am Ende.

Das wiederholte ' ':rsieht verschwenderisch aus. Ist a%(b:t@(' ':r))=b:a:taber gleich lang und a%(b:t)|' ':_<-t=b:a:tist ein Byte länger.


Haskell , 41 Bytes

f(a:b:t)|t<"A"=b:a:f t|1>0=a:f(b:t)
f e=e

Probieren Sie es online!


1

sed , 20 17 + 1 (-r) = 18 Bytes

s/(.)(.)\b/\2\1/g

Probieren Sie es online!


Der TIO-Link stimmt nicht mit Ihrem veröffentlichten Code überein. Die TIO-Verbindung ist einige Bytes länger.
Xcali

Whoops, den Link
behoben

Sie können entfernen |$. Es macht nichts. (Damit es das tut, was Sie erwarten (.)(.)(\b|$), ist es nicht erforderlich, da es \bbereits zum Ende der Zeichenfolge passt.)
Jordan

Hoppla, ich wollte das loswerden. Danke,
Noskcaj

1

PHP, 65 Bytes

benötigt PHP 7.1 (oder neuer)

for(;$s=$argv[++$i];$s[-1]=$s[-2],$s[-2]=$c,print"$s ")$c=$s[-1];

Nimmt den Satz als separate Befehlszeilenargumente. Laufen Sie mit -nr.


Arbeiten an einer einzelnen Zeichenfolge, 77 + 1 Byte :

foreach(explode(" ",$argn)as$s){$c=$s[-1];$s[-1]=$s[-2];$s[-2]=$c;echo"$s ";}

Als Rohr mit laufen lassen -nR.


... oder online ausprobieren .


1

Java 8, 35 Bytes

s->s.replaceAll("(.)(.)\\b","$2$1")

Port von @TaylorScotts Google Sheets antwortet , nachdem ich zwei Bytes golfen habe. EDIT: Ich sehe, es ist jetzt eine Portierung von Neils Retina-Antwort nach meinen zwei Golf-Bytes.

Erläuterung:

Probieren Sie es online aus.

s->                           // Method with String as both parameter and return-type
   s.replaceAll("(.)(.)       //  Replace any two characters,
                       \\b",  //  with a word-boundary after it (space or end of String)
                "$2$1")       //  With the two characters swapped

1

Google Sheets, 33 Bytes

Anonyme Arbeitsblattfunktion, die Eingaben aus der Zelle A1und Ausgaben in die aufrufende Zelle übernimmt

=RegExReplace(A1,"(.)(.)\b","$2$1

-2 Bytes Danke an @KevinCruijssen für die Verwendung von (.)über(\w)


Beides (\w)kann man spielen, (.)wenn ich mich nicht irre. Das \bist schon ein Hinweis, nur nach Worten zu suchen. (Nicht ganz sicher, aber es funktioniert in Java.)
Kevin Cruijssen

@ KevinCruijssen - Sie sind absolut richtig, es kann sein. Vielen Dank!
Taylor Scott

1

JavaScript (Node.js) , 38 36 32 Bytes

s => s.replace (/ (.) (.) (| $) / g, "$ 2 $ 1") 
s=>s.replace(/(.)(.)\b/g,"$2$1")

Probieren Sie es online!

RegExp-Annäherung mit freundlicher Genehmigung von @ Giuseppe (obwohl ich unabhängig davon darüber nachgedacht habe), unter der Annahme von Wörtern, die nur durch ein Leerzeichen getrennt sind

-2 für die Berücksichtigung von nur 1 Leerzeichen und das Hinzufügen von Leerzeichen am Ende

-4 Danke @Shaggy


Es spielt keine Rolle, ob es mehr Leerzeichen gibt, denke ich
l4m2

@ l4m2 Aber wenn es mehr Leerzeichen gibt, wird es eine 38 für s=>s.replace(/(.)(.)( +|$)/g,"$2$1$3").
Shieru Asakoto

@ 14m2 BTW meine ursprüngliche Antwort wars=>s.replace(/(.)(.)(\s|$)/g,"$2$1$3")
Shieru Asakoto

ab abc abcd abcde abcdef Does ab_, bc_, cd_, de_, ___, ef_,___
l4m2

1
F=s=>s.replace(/(.)(.)(?!\w)/g,"$2$1")gleiche Länge
l4m2

1

K (OK) , 23 22 Bytes

" "/{x@prm[!#x]1}'" "\

Probieren Sie es online!

Beispiel:

" "/{x@prm[!#x]1}'" "\"Hello World"
"Helol Wordl"

Erläuterung:

Portierung der FrownyFrog -Lösung, um 1 Byte zu sparen .

Ich werde darauf zurückkommen.

" "/{prm[x]1}'" "\ / the solution
              " "\ / split input on " "
    {       }'     / apply lambda to each
     prm[x]        / permute input x
           1       / and take the 2nd result
" "/               / join with " "

Vorherige Lösung:

  • " "/-2{(x_y),|x#y}'" "\ 23 Bytes

1

05AB1E , 7 Bytes

#vy`sðJ

Probieren Sie es online!

-1 dank Magic Octopus Urn .

Druckt ein Leerzeichen nach.


Dies ist 11 Bytes
Daniel W.

2
@DanFromGermany No, 05AB1E hat eine Codepage, in der dies als 8 Byte dargestellt werden kann.
Erik der Outgolfer

Können Sie das in 8 Bytes dargestellte Programm ausführen?
Daniel W.

@DanFromGermany Ja, der 05AB1E-Interpreter kann dieses Programm von einer Datei in der 05AB1E-Codierung ausführen.
Erik der Outgolfer

1
@MagicOctopusUrn Es ist aber keine Liste, es ist danach `.
Erik der Outgolfer


0

SNOBOL4 (CSNOBOL4) , 136 119 Bytes

	I =INPUT
B	I SPAN(&LCASE &UCASE) . Y ARBNO(' ') =:F(O)
	Y RPOS(2) REM . Z =REVERSE(Z)
	O =O Y ' '	:(B)
O	OUTPUT =O
END

Probieren Sie es online!

Druckt mit einem Leerzeichen nach. Sie wissen, dass Sie etwas falsch gemacht haben, wenn eine Sprache ein Backronym für ist StriNg Oriented und symBOlic Language ist und Ihr Code länger als Brain-Flak ist :( Jetzt ist es etwas besser.

Linie B nimmt Iund ersetzt (alphabetic characters saved as Y)(some number of spaces)durch die leere Zeichenfolge.

Die folgende Zeile extrahiert die letzten 2 Zeichen von Yas Zund ersetzt sie alsZ umgekehrt, dann die nächste Zeile verkettet O, Yund ein einzelnes Leerzeichen.

Schließlich wird gedruckt, wenn Idas erforderliche Muster in der Zeile nicht mehr übereinstimmt B.


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.