Beginnen wir mit der Definition einer Reflexion eines Zeichens in einer Zeichenfolge:
Definieren Sie bei einer Zeichenfolge mit eindeutigen alphabetischen Kleinbuchstaben ohne Leerzeichen abcdefg
eine Reflektion eines Buchstabens in der Zeichenfolge c
als Verschieben (ohne die Reihenfolge eines anderen Buchstabens zu ändern) an eine neue Stelle in der Zeichenfolge, sodass die Anzahl der ursprünglichen Buchstaben erhalten bleibt rechts davon steht nun die anzahl der buchstaben links davon.
Somit wird eine Reflexion des Schreibens c
in abcdefg
wäre abdecfg
. Erklärung: Es waren 4 Buchstaben rechts c
und jetzt sind es 4 Buchstaben links von c
.
Einige weitere Beispiele:
Das Reflektieren des Zeichens e
in myfriend
würde die Zeichenfolge bildenmyefrind
Das Reflektieren des Zeichens a
in axyz
würde die Zeichenfolge bilden xyza
.
Das Reflektieren des Zeichens b
in abc
würde die Zeichenfolge bilden abc
.
Das Reflektieren des Zeichens d
in d
würde die Zeichenfolge bilden d
.
Das Reflektieren des Zeichens e
in ef
würde die Zeichenfolge bilden fe
.
Für weitere Informationen oder um einige Testfälle auszuprobieren, ist hier ein (etwas langes) Programm, das ich in C ++ geschrieben habe.
Die Herausforderung
Gehen Sie bei einer Zeichenfolge mit unterschiedlichen Kleinbuchstaben jedes Zeichen alphabetisch durch und "reflektieren" Sie es in der Zeichenfolge.
Erläuterungen: Die Buchstaben in der Zeichenfolge sind aus a-z
, es gibt keine Leerzeichen, die Buchstaben sind eindeutig und die Zeichenfolge ist mindestens 1 Buchstabe und höchstens 26 Buchstaben lang.
Beispiele
Input: dcba
. Ausgang: dcba
.
Grund: Reflektieren a
Sie zunächst das Zeichen in der Zeichenfolge, das im Alphabet am frühesten kommt. Du wirst bekommen adcb
. Dann reflektiere das, b
wie es als nächstes im Alphabet kommt, um es zu bekommen badc
. Dann reflektiere das c
zu bekommen cbad
und dann das d
zu bekommen dcba
.
Input: myface
. Ausgang: fyecma
.
Tipp: Gehen Sie die Buchstaben in der Reihenfolge durch a, c, e, f, m, y
.
Input: a
. Ausgang: a
.
Input: acb
. Ausgang: bac
.
Input: cwmfjordbankglyphsvextquiz
. Ausgang: ieabhqzugdltkfnvpjxsormycw
.
Wertung
- Die Eingabe und Ausgabe kann durch jede bequeme Methode erfolgen .
- Es ist entweder ein vollständiges Programm oder eine Funktion zulässig. Bei einer Funktion können Sie die Ausgabe zurückgeben, anstatt sie zu drucken.
- Standardlücken sind verboten.
- Dies ist Codegolf, daher gelten alle üblichen Golfregeln, und der kürzeste Code (in Byte) gewinnt.
- Annahme ~ 100 Stunden nach der Veröffentlichung.
Aktueller Gewinner
<style>body { text-align: left !important} #answer-list { padding: 10px; width: 290px; float: left; } #language-list { padding: 10px; width: 290px; float: left; } table thead { font-weight: bold; } table td { padding: 5px; }</style><script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <link rel="stylesheet" type="text/css" href="//cdn.sstatic.net/codegolf/all.css?v=83c949450c8b"> <div id="language-list"> <h2>Shortest Solution by Language</h2> <table class="language-list"> <thead> <tr><td>Language</td><td>User</td><td>Score</td></tr> </thead> <tbody id="languages"> </tbody> </table> </div> <div id="answer-list"> <h2>Leaderboard</h2> <table class="answer-list"> <thead> <tr><td></td><td>Author</td><td>Language</td><td>Size</td></tr> </thead> <tbody id="answers"> </tbody> </table> </div> <table style="display: none"> <tbody id="answer-template"> <tr><td>{{PLACE}}</td><td>{{NAME}}</td><td>{{LANGUAGE}}</td><td>{{SIZE}}</td><td><a href="{{LINK}}">Link</a></td></tr> </tbody> </table> <table style="display: none"> <tbody id="language-template"> <tr><td>{{LANGUAGE}}</td><td>{{NAME}}</td><td>{{SIZE}}</td><td><a href="{{LINK}}">Link</a></td></tr> </tbody> </table><script>var QUESTION_ID = 162891; var ANSWER_FILTER = "!t)IWYnsLAZle2tQ3KqrVveCRJfxcRLe"; var COMMENT_FILTER = "!)Q2B_A2kjfAiU78X(md6BoYk"; var OVERRIDE_USER = 12012; var answers = [], answers_hash, answer_ids, answer_page = 1, more_answers = true, comment_page; function answersUrl(index) { return "https://api.stackexchange.com/2.2/questions/" + QUESTION_ID + "/answers?page=" + index + "&pagesize=100&order=desc&sort=creation&site=codegolf&filter=" + ANSWER_FILTER; } function commentUrl(index, answers) { return "https://api.stackexchange.com/2.2/answers/" + answers.join(';') + "/comments?page=" + index + "&pagesize=100&order=desc&sort=creation&site=codegolf&filter=" + COMMENT_FILTER; } function getAnswers() { jQuery.ajax({ url: answersUrl(answer_page++), method: "get", dataType: "jsonp", crossDomain: true, success: function (data) { answers.push.apply(answers, data.items); answers_hash = []; answer_ids = []; data.items.forEach(function(a) { a.comments = []; var id = +a.share_link.match(/\d+/); answer_ids.push(id); answers_hash[id] = a; }); if (!data.has_more) more_answers = false; comment_page = 1; getComments(); } }); } function getComments() { jQuery.ajax({ url: commentUrl(comment_page++, answer_ids), method: "get", dataType: "jsonp", crossDomain: true, success: function (data) { data.items.forEach(function(c) { if (c.owner.user_id === OVERRIDE_USER) answers_hash[c.post_id].comments.push(c); }); if (data.has_more) getComments(); else if (more_answers) getAnswers(); else process(); } }); } getAnswers(); var SCORE_REG = /<h\d>\s*([^\n,<]*(?:<(?:[^\n>]*>[^\n<]*<\/[^\n>]*>)[^\n,<]*)*),.*?(\d+)(?=[^\n\d<>]*(?:<(?:s>[^\n<>]*<\/s>|[^\n<>]+>)[^\n\d<>]*)*<\/h\d>)/; var OVERRIDE_REG = /^Override\s*header:\s*/i; function getAuthorName(a) { return a.owner.display_name; } function process() { var valid = []; answers.forEach(function(a) { var body = a.body; a.comments.forEach(function(c) { if(OVERRIDE_REG.test(c.body)) body = '<h1>' + c.body.replace(OVERRIDE_REG, '') + '</h1>'; }); var match = body.match(SCORE_REG); if (match) valid.push({ user: getAuthorName(a), size: +match[2], language: match[1], link: a.share_link, }); else console.log(body); }); valid.sort(function (a, b) { var aB = a.size, bB = b.size; return aB - bB }); var languages = {}; var place = 1; var lastSize = null; var lastPlace = 1; valid.forEach(function (a) { if (a.size != lastSize) lastPlace = place; lastSize = a.size; ++place; var answer = jQuery("#answer-template").html(); answer = answer.replace("{{PLACE}}", lastPlace + ".") .replace("{{NAME}}", a.user) .replace("{{LANGUAGE}}", a.language) .replace("{{SIZE}}", a.size) .replace("{{LINK}}", a.link); answer = jQuery(answer); jQuery("#answers").append(answer); var lang = a.language; lang = jQuery('<a>'+lang+'</a>').text(); languages[lang] = languages[lang] || {lang: a.language, lang_raw: lang.toLowerCase(), user: a.user, size: a.size, link: a.link}; }); var langs = []; for (var lang in languages) if (languages.hasOwnProperty(lang)) langs.push(languages[lang]); langs.sort(function (a, b) { if (a.lang_raw > b.lang_raw) return 1; if (a.lang_raw < b.lang_raw) return -1; return 0; }); for (var i = 0; i < langs.length; ++i) { var language = jQuery("#language-template").html(); var lang = langs[i]; language = language.replace("{{LANGUAGE}}", lang.lang) .replace("{{NAME}}", lang.user) .replace("{{SIZE}}", lang.size) .replace("{{LINK}}", lang.link); language = jQuery(language); jQuery("#languages").append(language); } }</script>
Antworten:
Brain-Flak , 188 Bytes
Probieren Sie es online!
Zusätzlich zu den in der Herausforderungsspezifikation beschriebenen Überlegungen kehrt dieser Code die Zeichenfolge genau 26 Mal um. Dies hat keine Auswirkung auf die endgültige Ausgabe.
quelle
05AB1E ,
2017 BytesProbieren Sie es online!
Erläuterung
Mit Beispiel für die erste Iteration von
myface
Die Zeichenfolge ist bei jeder Iteration mit Leerzeichen umgeben, da die Aufteilung auf den ersten oder letzten Buchstaben der Zeichenfolge andernfalls zu einer Liste der Länge 1 führt und die Zusammenführung diesen Buchstaben nicht enthält.
quelle
Pyth,
18161916 BytesProbieren Sie es hier aus
Erläuterung
quelle
Python 3 ,
8073 BytesVielen Dank an Esolanging Fruit, das mich daran erinnert hat, dass Funktionen durch Ändern ihres Arguments zurückkehren können.
Probieren Sie es online!
Übernimmt die Eingabe als Liste von Zeichen.
quelle
Python 2 , 70 Bytes
Probieren Sie es online!
Ändert die Eingabeliste
quelle
Retina 0.8.2 , 61 Bytes
Probieren Sie es online! Link enthält Testfälle. Erläuterung:
Starten Sie die Schleife bei
a
.Wenn die Eingabe den aktuellen Buchstaben enthält, verschieben Sie ihn an das Ende, wobei eine Zeichenfolge von
_
s die ursprüngliche Position darstellt.Für jeden
_
Zug rückt der Buchstabe ein Zeichen zurück.Erhöhe den Buchstaben. Nachdem Sie
z
es auf a geändert haben,!
stimmt es mit nichts überein und die Schleife endet.Löschen Sie die
!
.quelle
Java 8,
1409692888785 Bytes-44 Bytes, die einen Port von @TFelds Python 2-Antwort erstellen .
-6 Bytes dank @ OlivierGrégoire .
Ändert die Eingabeliste, anstatt eine neue zu erstellen.
Erläuterung:
Probieren Sie es online aus.
quelle
s->{for(char c=96;++c<123;){int i=s.indexOf(c);if(i>=0)s.add(s.size()+~i,s.remove(i));}}
for(char c=9;++c>1;)
ist es besser ;-)char
auch gerne umwickeltInteger.MAX_VALUE + 1 == Integer.MIN_VALUE
.. Schlau !s
ist eine ArrayList, alsoindexOf
ein generischer TypT
(Character
für diese Eingabeliste).JavaScript,
858079 Bytes-6 Bytes dank @DanielIndie
Probieren Sie es online!
quelle
Ruby , 51 Bytes
Probieren Sie es online!
Nimmt eine Reihe von Zeichen
Kehrt durch Ändern der Eingabe zurück
quelle
Rot ,
96 bis94 BytesKevin Cruijssen hat 2 Bytes gespart
Probieren Sie es online!
Besser lesbar:
quelle
find x c replace x c""insert at x i c
auffind x c insert at replace x c""i c
loszuwerden eine bekommenx
und Raum.R ,
737269 BytesProbieren Sie es online!
Eingabe und Ausgabe eines Zeichenvektors.
quelle
c
als Variablennamen verwenden? Das ist schrecklich, auch für Code Golf!c
fürchar
) einen Sinn zu bewahren als in nicht verwendeten eingebauten Funktionen.c
, und es war schrecklich, als ich nicht herausfinden konnte, was passierte. Ich benutze normalerweiseK
oderk
oder auchC
nur Probleme wie das zu vermeiden, aber ich es total bekommen.append
ist auf jeden Fall das richtige Werkzeug für den Job.Perl 5
-p
, 37 BytesProbieren Sie es online!
quelle
Japt ,
2322 BytesEin Byte gespart dank Oliver .
Probieren Sie es online!
quelle
,É
mitJ
Haskell, 87 Bytes
Probieren Sie es online!
quelle
f s=foldl(#)s['a'..'z']
?['a'..]
ist nicht unendlich, daChar
zur Klasse gehörtBounded
. Eine Liste mit..]
vonBounded
Werten hält anmaxBound
. Versuchen:print [False ..]
.SNOBOL4 (CSNOBOL4) ,
132128 BytesProbieren Sie es online!
Einfache Implementierung des erforderlichen Algorithmus. Ein paar Bytes gespart, indem zu einer Funktion anstatt zu einem vollständigen Programm gewechselt wurde. Die Erklärung bleibt mehr oder weniger dieselbe.
quelle
Jelly ,
1211 BytesEin monadischer Link, der eine Liste von Zeichen akzeptiert und eine Liste von Zeichen zurückgibt.
Probieren Sie es online!
Wie?
quelle
ḟ
(filter out) zu speichern , aber ich habe es noch nicht geschafft.sorted
und dann n Iterationen von scheinbar weniger komplexen Operationen (Abflachen, Teilen bei gefundenen Indizes, Verbinden, Umkehren) durchläuft ). - und Pythonssorted
ist O (n log n).C (clang) ,
164–162BytesProbieren Sie es online!
f()
Verwendet das Zeichen-Array, das die Eingabezeichenfolge und die Länge dieses Arrays enthält, als Parameter und führt die erforderlichen Überlegungen durch.callf()
macht hübsches Drucken.Credits
-2 Bytes. @ Kevin. Vielen Dank
quelle
char *s
und änderni=96
zui=9
zu speichern 2 Byte.a
. Vielen DankAPL + WIN, 63 Bytes
Fordert zur Eingabe einer Zeichenfolge auf
Erläuterung:
quelle
Perl ,
74Bytes8480 Bytes inklusive Aufruf als Unix-Filterquelle