16
1
Let's start by re-defining a reflection of a character in a 2-d array of characters:
Given a square 2-d array of characters with distinct lowercase alphabetical letters, define a reflection of a letter in the matrix as swapping it with the character directly across from it through the center of the square.
Thus, a reflection of the letter c
in
abcde
fghij
klmno
pqrst
uvwxy
would result in the configuration
abwde
fghij
klmno
pqrst
uvcxy
because the c
and the w
have been switched.
Some more examples (with the same original configuration as above):
Reflecting the character
e
would form
abcdu
fghij
klmno
pqrst
evwxy
Reflecting the character
m
would make
abcde
fghij
klmno
pqrst
uvwxy
Reflecting the character
b
would form
axcde
fghij
klmno
pqrst
uvwby
The Challenge
Given a 2-d array of characters with distinct lowercase letters, go through each character in a given string and "reflect" it in the matrix.
Clarifications: The letters in the string are from a-z
, the letters are unique, and the array is at least 1x1 and at most 5x5 (obviously, as there are only 26 characters in the English alphabet.) The characters in the string are guaranteed to be in the 2-d array. The string is at most 100 characters long.
Input
An string s
, an integer N
, and then a NxN
array of characters.
Example
Input:
ac
2
ab
cd
Output:
dc
ba
*Reason: First, reflect the a
with the d
. Then, reflect the c
with the b
because c
is the second letter in the input string.
Scoring
- Output can be given by any convenient method.
- Either a full program or a function are acceptable. If a function, you can return the output rather than printing it.
- Standard loopholes are forbidden.
- This is code-golf so all usual golfing rules apply, and the shortest code (in bytes) wins.
Current Winner
<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>
9Half an hour is not really enough time to get any meaningful use out of the sandbox. – Post Rock Garf Hunter – 2018-04-23T04:22:33.083
Sigh I thought of that, but then I realized it was so much like my previous question that I didn't think it needed Sandbox. I apologize if this puzzle is bad :( – NL628 – 2018-04-23T04:49:02.600
3No problem, it looks good. – user202729 – 2018-04-23T05:12:11.247
1
(also we have a Stack snippet leaderboard)
– user202729 – 2018-04-23T05:12:26.537@user202729 Thanks! Should I give credit? Or is it just something everyone uses. Sorry, I'm kind of new to this. – NL628 – 2018-04-23T05:15:41.347
650 hours is a bit too short of a time span to accept a winner; typically you'd want to wait a week or so. However, on PPCG, it's common practice to not accept any answers because that discourages future answers, and we want to keep challenges open forever. – HyperNeutrino – 2018-04-23T05:25:55.743
@HyperNeutrino Thanks! This is very, very different from Puzzling SE which is where I spend the majority of my time, so thanks for letting me know! :D – NL628 – 2018-04-23T05:38:52.343
@NL628 No problem! Glad to have you here – HyperNeutrino – 2018-04-23T07:09:31.383
2All you examples have the characters in alphabetical order. I assume that's not an assumption we can make? Also, do we have to take
N
as an input if we don't need it? – Stewie Griffin – 2018-04-23T07:43:51.013"The string is at most 100 characters long". Does that mean we can get input:
'aaaabbaabbaabaccccaac',2,'ab\ncd'
? I think you should give a test case like that, if it's a possible input. – Stewie Griffin – 2018-04-23T08:04:50.340Can we take the character array as a string instead? – darrylyeo – 2018-04-23T21:57:17.760