Comencemos redefiniendo un reflejo de un personaje en una matriz de caracteres en 2-d:
Dada una matriz cuadrada de caracteres en 2-d con letras alfabéticas en minúsculas distintas, defina un reflejo de una letra en la matriz como intercambiándola con el carácter directamente enfrente del centro del cuadrado.
Por lo tanto, un reflejo de la letra cen
abcde
fghij
klmno
pqrst
uvwxy
daría lugar a la configuración
abwde
fghij
klmno
pqrst
uvcxy
porque el cy el whan sido cambiados.
Algunos ejemplos más (con la misma configuración original que la anterior):
Reflejando el personaje ese formaría
abcdu
fghij
klmno
pqrst
evwxy
Reflejar el personaje mharía
abcde
fghij
klmno
pqrst
uvwxy
Reflejando el personaje bse formaría
axcde
fghij
klmno
pqrst
uvwby
El reto
Dada una matriz de caracteres en 2-d con letras minúsculas distintas, revise cada carácter en una cadena dada y "refleje" en la matriz.
Aclaraciones: las letras de la cadena son de a-z, las letras son únicas y la matriz es de al menos 1x1 y como máximo 5x5 (obviamente, ya que solo hay 26 caracteres en el alfabeto inglés). Se garantiza que los caracteres de la cadena serán en la matriz de 2-d. La cadena tiene como máximo 100 caracteres de longitud.
Entrada
Una cadena s, un número entero Ny luego una NxNserie de caracteres.
Ejemplo
Entrada:
ac
2
ab
cd
Salida:
dc
ba
* Motivo: Primero, refleje acon el d. Luego, refleja el ccon el bporque ces la segunda letra en la cadena de entrada.
Puntuación
- La salida se puede dar por cualquier método conveniente .
- Un programa completo o una función son aceptables. Si es una función, puede devolver el resultado en lugar de imprimirlo.
- Las lagunas estándar están prohibidas.
- Este es el código de golf, por lo que se aplican todas las reglas habituales de golf, y gana el código más corto (en bytes).
Ganador actual
<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>
Ncomo entrada si no lo necesitamos?Respuestas:
Octava ,
856866 bytes¡Usando
eval, con un bucle dentro, ahorró muchos bytes! ¡Recibí la inspiración de esta respuesta de Luis Mendo !Pruébalo en línea!
Explicación:
fuente
Python 2 , 76 bytes
Pruébalo en línea!
Toma entrada:
s: cuerdaN: ignoradoa: cadena de caracteres unidaDevuelve una lista plana de caracteres
Si tengo que tomar la matriz como una lista:
Python 2 ,
111108107104 bytesPruébalo en línea!
Toma entrada:
s: cuerdan: En ta: Listas 2D de caracteresDevuelve una lista 2D de caracteres
fuente
Java 10,
126123116 bytesModifica la matriz de caracteres de entrada en lugar de devolver una nueva para guardar bytes.
Pruébalo en línea.
Explicación:
fuente
Python 3 ,
122111 bytesPruébalo en línea!
Devuelve una matriz 2D de caracteres.
fuente
aandband usingn+~xyn+~ydirectamente ahorra 2 bytes:a,b=n+~x,n+~y;A[x][y],A[a][b]=A[a][b],A[x][y]aA[x][y],A[n+~x][n+~y]=A[n+~x][n+~y],A[x][y]R ,
7461 bytes-13 bytes gracias a Giuseppe.
Pruébalo en línea!
Introduce un vector de caracteres para buscar como
s, tamaño de la matriz comony matriz comom. Si es absolutamente necesario tomar el primer argumento como una cadena , eso arruinaría la diversión.fuente
Jalea ,
1514 bytesPruébalo en línea!
Programa completo
Explicación:
FW; Ṛi, C $ ¥ ¦ / ṁḷY Enlace principal. Entrada: ['ab', 'cd'] (izquierda), 'ac' (derecha). FW F latten y W rap en una lista. Valor actual = ['abcd']. ; Concatenarlo con el argumento correcto. ['abcd', 'a', 'c'] / Reducir desde la izquierda: Ṛ ¦ Aplicar Ṛ everse en ... i ¥ el índice (del argumento derecho en el argumento izquierdo) ... , C $ y su índice de complemento.La última operación necesita más explicación. Denote f =
Ṛi,C$¥¦, luego, para el valor['abcd','a','c']que calcula('abcd' f 'a') f 'c', que se expande a:Ṛi, C $ ¥ ¦ Función f . Asumir argumento izquierdo = 'abcd' y argumento derecho = 'a' Ṛ Primero, calcule el reverso. Obtenga 'dcba'. i ¥ Para calcular los índices a aplicar, primero el índice de 'a' en 'abcd' is ('abcd' i 'a') = 1. (primer índice) , C $ Luego emparejar con (1 C) = 0. (último índice) ¦ Aplicar 'dcba' a 'abcd' en los índices 0 y 1: a bc d d cb a ^ 1 ^ 0 ==== dbcafuente
Retina 0.8.2 , 96 bytes
Pruébalo en línea! Toma la cadena
sy la matriz de caracteres como una cadena delimitada por una nueva línea sin el enteroN. Explicación: Cada caráctercdesse procesa a su vez. La expresión regular coincide con dos posiciones equidistantes de los extremos de la matriz, de las cuales una escy la otra es su espejom. Estos caracteres se intercambian ycse eliminan des.Procesa cada personaje de
sa su vez.$1capturasc.$3captura una pila de caracteres en la matriz con el prefijo uno decom.$2captura el resto desmás todos estos personajes.Si
mprecedec,$4tiene un valor,$5capturamy$6captura los caracteres entremyc.$7captura$6como una pila pero su valor no se utiliza.cahora coincide en la matriz misma.Si aún
mno coincidía, entonces$8opcionalmente captura un valor, en cuyo caso$9captura los caracteres decam,$10captura$9como una pila que no se utiliza y$11capturam. El valor es opcional en el casocymson del mismo carácter.$12captura los personajes sufijando el otro decym. Se utiliza un grupo de equilibrio para garantizar que$12sea tan largo como$3profundo, es decir, el prefijo y el sufijo tienen la misma longitud.Luego, las piezas se vuelven a unir: primero el resto
sy el prefijo de la matriz, luego si estácprecedidom,mluego el medio, luegoc, si estámprecedido,cluego el medio ymluego el sufijo.Ahora que
sestá vacío, se elimina.fuente
JavaScript, 85 bytes
Toma una cadena
Sy una matrizAcomo una cadena unida.Mostrar fragmento de código
fuente
Perl 5
-lpF, 97 bytesPruébalo en línea!
fuente