Beginnen wir damit, eine Reflektion eines Zeichens in einem 2D-Array von Zeichen neu zu definieren:
Definieren Sie bei einem quadratischen 2-d-Array von Zeichen mit unterschiedlichen alphabetischen Kleinbuchstaben ein Abbild eines Buchstabens in der Matrix, indem Sie es durch die Mitte des Quadrats mit dem Zeichen direkt gegenüber vertauschen.
So ein Spiegelbild des Buchstabens c
in
abcde
fghij
klmno
pqrst
uvwxy
würde in der Konfiguration führen
abwde
fghij
klmno
pqrst
uvcxy
weil die c
und die w
geschaltet worden sind.
Einige weitere Beispiele (mit derselben ursprünglichen Konfiguration wie oben):
Das Reflektieren des Charakters e
würde sich bilden
abcdu
fghij
klmno
pqrst
evwxy
Den Charakter zu reflektieren m
würde machen
abcde
fghij
klmno
pqrst
uvwxy
Das Reflektieren des Charakters b
würde sich bilden
axcde
fghij
klmno
pqrst
uvwby
Die Herausforderung
Bei einem 2-d-Array von Zeichen mit unterschiedlichen Kleinbuchstaben durchlaufen Sie jedes Zeichen in einer bestimmten Zeichenfolge und "reflektieren" es in der Matrix.
Erläuterungen: Die Buchstaben in der Zeichenfolge stammen von a-z
, die Buchstaben sind eindeutig, und das Array ist mindestens 1x1 und höchstens 5x5 (offensichtlich, da das englische Alphabet nur 26 Zeichen enthält). Die Zeichen in der Zeichenfolge sind garantiert in der 2-d-Anordnung. Die Zeichenfolge ist höchstens 100 Zeichen lang.
Eingang
Eine Zeichenfolge s
, eine Ganzzahl N
und dann ein NxN
Array von Zeichen.
Beispiel
Eingang:
ac
2
ab
cd
Ausgabe:
dc
ba
* Grund: Reflektiere zuerst das a
mit dem d
. Dann spiegeln Sie das c
mit dem, b
weil c
der zweite Buchstabe in der Eingabezeichenfolge ist.
Wertung
- Die Ausgabe kann auf jede bequeme Weise 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.
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 = 163084; 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>
N
als eine Eingabe , wenn wir es nicht brauchen?Antworten:
Oktave ,
856866 BytesDurch die Verwendung
eval
einer Schleife wurden viele Bytes gespart! Diese Antwort von Luis Mendo hat mich inspiriert !Probieren Sie es online!
Erläuterung:
quelle
Python 2 , 76 Bytes
Probieren Sie es online!
Übernimmt die Eingabe:
s
: stringN
: ignorierta
: Zeichenfolge verbundenGibt eine flache Liste von Zeichen zurück
Wenn ich habe das Array als Liste in Anspruch nehmen:
Python 2 ,
111108107104 BytesProbieren Sie es online!
Übernimmt die Eingabe:
s
: stringn
: inta
: 2D-Listen von ZeichenGibt eine 2D-Liste von Zeichen zurück
quelle
Java 10,
126123116 BytesÄndert die eingegebene Zeichenmatrix, anstatt eine neue zurückzugeben, um Bytes zu speichern.
Probieren Sie es online aus.
Erläuterung:
quelle
Python 3 ,
122111 BytesProbieren Sie es online!
Gibt ein 2D-Array von Zeichen zurück.
quelle
a
undb
und mitn+~x
undn+~y
speichert direkt 2 Bytes:a,b=n+~x,n+~y;A[x][y],A[a][b]=A[a][b],A[x][y]
zuA[x][y],A[n+~x][n+~y]=A[n+~x][n+~y],A[x][y]
R ,
7461 Bytes-13 Bytes dank Giuseppe.
Probieren Sie es online!
Gibt einen Vektor von Zeichen für die Suche
s
, die Größe der Matrix alsn
und die Matrix selbst als einm
. Wenn es absolut notwendig ist, das erste Argument als Zeichenfolge zu verwenden , würde dies den Spaß ziemlich beeinträchtigen.quelle
Jelly ,
15 bis14 BytesProbieren Sie es online!
Volles Programm.
Erläuterung:
Die letzte Operation bedarf weiterer Erklärung. Bezeichne f =
Ṛi,C$¥¦
, dann berechnet['abcd','a','c']
es für den Wert('abcd' f 'a') f 'c'
, der erweitert wird zu:quelle
Retina 0,8,2 , 96 Bytes
Probieren Sie es online! Nimmt die Zeichenfolge
s
und das Zeichenarray als durch Zeilenumbrüche getrennte Zeichenfolge ohne die GanzzahlN
. Erläuterung: Jedes Zeichenc
vons
wird nacheinander verarbeitet. Der reguläre Ausdruck entspricht zwei Positionen mit gleichem Abstand von den Enden des Arrays, von denen die einec
und die andere der Spiegel istm
. Diese Zeichen werden ausgetauscht und ausc
entfernts
.Verarbeitet jeden Charakter der
s
Reihe nach.$1
erfasstc
.$3
Erfasst einen Stapel von Zeichen im Array mit dem Präfixc
oderm
.$2
erfasst den Rest vons
plus all diesen Zeichen.Wenn
m
vorangehtc
,$4
hat einen Wert,$5
erfasstm
und$6
erfasst die Zeichen zwischenm
undc
.$7
erfasst$6
als Stapel, aber sein Wert wird nicht verwendet.c
wird jetzt im Array selbst abgeglichen.Wenn
m
nicht bereits abgestimmt, dann$8
fängt optional einen Wert, in welchem Fall$9
die Zeichen von fängtc
anm
,$10
erfasst$9
als Stapel , die nicht benutzt wird und$11
erfasstm
. Der Wert ist in diesem Fall optionalc
und hatm
dasselbe Zeichen.$12
fängt die Zeichen ein, die mit dem Suffix des anderen vonc
undm
. Mit einer Bilanzgruppe wird sichergestellt, dass$12
die Länge so lang ist, wie sie$3
tief ist, dh Präfix und Suffix sind gleich lang.Die Stücke werden dann wieder zusammengesetzt - zuerst den Rest
s
und das Präfix des Arrays, dann , wennc
vorausgegangenm
dannm
dann die Mitte, dannc
, dann , wennm
vorangegangen ist,c
dann die Mittem
, dann das Suffix.Nun
s
ist das leer, es wird gelöscht.quelle
JavaScript, 85 Bytes
Nimmt string
S
und ein ArrayA
als verknüpften String.Code-Snippet anzeigen
quelle
Perl 5
-lpF
, 97 BytesProbieren Sie es online!
quelle