/* Configuration */
var QUESTION_ID = 61940; // Obtain this from the url
// It will be like http://XYZ.stackexchange.com/questions/QUESTION_ID/... on any question page
var ANSWER_FILTER = "!t)IWYnsLAZle2tQ3KqrVveCRJfxcRLe";
var COMMENT_FILTER = "!)Q2B_A2kjfAiU78X(md6BoYk";
var OVERRIDE_USER = 43444; // This should be the user ID of the challenge author.
/* App */
var answers = [], answers_hash, answer_ids, answer_page = 1, more_answers = true, comment_page;
function answersUrl(index) {
return "http://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 "http://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, 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.toLowerCase() > b.lang_raw.toLowerCase()) return 1;
if (a.lang_raw.toLowerCase() < b.lang_raw.toLowerCase()) 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);
}
}
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;
}
<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>
Hello, World!
?Respuestas:
Pyth, 19 bytes
Pruébelo en línea: Demostración o conjunto de pruebas
Explicación
fuente
Python 2.7,
1009896 bytesfuente
TeaScript , 24 bytes
2628TeaScript es JavaScript para jugar al golf
Muy corto
Pruébalo en línea
Explicación
fuente
Rubí,
1378782766755 bytesUngolfed, pero puedes ver el patrón.
Editar: golfed a solo una expresión regular.
Edición 2: tenía muchos espacios extra.
Edición 3: ¡Gracias a manatwork por jugar al golf en 12 bytes!
fuente
$><<gets.gsub(/[a-z0-9]/i){[*" 0Aa"[$&.ord/32]..$&]*""}
Python 2,
145140133103102 BytesUna función anónima no tan elegante que utiliza la comprensión de listas. Siento que la lógica debería ser mucho más corta, intentaré resolver algo.
Se le debe dar un nombre para ser utilizado, es decir
f=...
fuente
Haskell,
95918660 bytesEjemplo de uso:
f "pi=3.14159"
->"abcdefghijklmnopabcdefghi=0123.0101234010123450123456789"
Cómo funciona: copie todos los caracteres en la cadena de entrada a menos que c esté en el medio de
A
/Z
,a
/z
o0
/9
y, de ser así, tome la lista de[<first char in pair> ... <c>]
.Editar: @Zgarb guardó muchos bytes. ¡Gracias!
fuente
c#_=[c]
y omitir port
completo.s
también es superfluo. ¡Muchas gracias!JavaScript (ES6),
143138 bytesUtiliza comparaciones de cadenas para probar qué caracteres usar.
Demo en línea. Probado en Firefox y Chrome.
Editar: guardado 5 bytes reemplazando
a='0123456789abcdefghijklmnopqrstuvwxyz'
confuente
PHP, 146 bytes
Golfed
Revisión 1: poner rangos ord directamente en foreach. incrementó el rango ord máximo y cambió
$d<=$m
a$d<$m
. usandofor
para iterar caracteres en lugar deforeach
ystr_split
. Eliminado todo{}
moviendo el código afor
Sin golf
Explicación: dividir la cadena en una matriz. Si el valor ascii cae en un rango (para az, AZ, 0-9), incremente un contador desde el mínimo del rango hasta el valor ascii del personaje, agregando cada valor hasta llegar al valor ascii del personaje.
Pasé por
&$var
lo que la salida se hace por referencia en lugar de unreturn
fuente
foreach
.range()
? pastebin.com/k2tqFEgD$z
e hice algunos otros cambios.range()
probablemente sería mejor Podría intentar algo con rango más tarde.range
, obtuvefunction f($n,&$l){$o=['a'=>'z','A'=>'Z','0'=>'9'];foreach(str_split($n) as $c){$b=0;foreach($o as $m=>$x)!($c>$m&&$c<=$x)?:$b=$l.=implode(range($m,$c));$b?:$l.=$c;}}
, que era 166.range()
es menos beneficioso. Pero ese 166 es demasiado largo aún: el $ o para el literal de matriz está de vuelta, hay espacios adicionales alrededor de lasas
palabras clave,join()
es un alias paraimplode()
. (?. Comprobado el código de Pastebin he vinculado anteriormente muestra otra posibilidad de almacenar los puntos finales de rango) En cuanto a su solución de 146 caracteres, se puede mover la asignación de $ c dentro de laord()
llamada:$d=ord($c=$n[$r])
.Python, 143 bytes
Pruébalo en línea
fuente
Perl 6, 101 bytes
Aquí hay un primer paso:
119
Utilizando
.trans
el$_
de eliminaris copy
.106
Actúa
@*ARGS
directamente en lugar de definir unMAIN
sub.(de lo contrario, idéntico al ejemplo anterior)
101
fuente
Scala,
11191 bytesfuente
pi=3.14159
. ¿Podría ser la soluciónval f=(_:String).flatMap(x:String=>if(x.isDigit)('0'to x)else if(x.isUpper)('A'to x)else if(x.isLower)('a'to x)else x.toString)
para la friolera de 128 caracteres?Julia,
102989084 bytesEsto crea una función sin nombre que acepta una cadena y devuelve una cadena.
Sin golf:
fuente
PowerShell, 155 bytes
Técnicamente una línea, y PowerShell se trata de eso ;-)
Divide la entrada, canaliza eso en un
ForEach-Object
bucle, activa el valor entero del personaje de lanzamiento, luego genera nuevoschar[]
rangos apropiados. Tenga en cuenta que tenemos que gastar bytes para establecer una variable temporal$b
porque el acto de emitir la entrada$_
en la declaración del interruptor significa que no podemos seguir usando$_
o obtendremos resultados extravagantes.EDITAR: debo señalar que esto eliminará los errores ya que el primer objeto que se alimenta
%{...}
es un objeto nulo. Dado que STDERR se ignora por defecto , esto no debería ser un problema. Si es un problema, cambie el primer bit($args-split''-ne''|...
para eliminar el objeto nulo.fuente
JavaScript (ES6),
340258273271 bytesfuente
("")
yf=i=""
en el bucle for. Es posible que pueda guardar algunos bytes más.C (269 bytes)
(salto de línea agregado para mayor claridad)
Sin golf
fuente
Perl 5 ,
6661(51 Bytes + 1) 52La combinación de expresiones regulares con operadores condicionales funcionó bien en este caso.
Con una uniónUso del mapa para combinar los rangos en una matriz.Prueba
Explicación
fuente
JavaScript (ES7), 125 bytes
Ya había dos respuestas JS centradas en la codificación de las cadenas, así que decidí optar por un enfoque más algorítmico utilizando
String.fromCharCode()
:Una ventaja de usar este método es que requiere cualquier cantidad de códigos de caracteres, por
join
lo que no es necesario ingresar la lista. Esto resultó más corto que cualquier otra técnica, así que estoy contento con el resultado.fuente
MUMPS, 131 bytes
Logré guardar unos pocos bytes aquí gracias al alcance dinámico de MUMPS . Aquí hay una versión sin golfing más o menos equivalente, que seguramente me encantaría resaltar sintaxis, si solo estuviera disponible el soporte para el módulo MUMPS Prettify .
fuente
Perl 6,
7877 bytesfuente
'a'..'z'
y'A'..'Z'
los casos, debería haber esforzado más.<!-- language-all: lang-perl6 -->
justo después## Perl 6
para que se resalte correctamente. (El cambio ya está pendiente en esta respuesta){[~](0..$/)}
a{[~] 0..$/}
cuál guardará un byte.Mathematica, 102 bytes
Oh bien...
fuente
CJam,
3231 bytesPruébelo en línea en el intérprete de CJam .
Cómo funciona
fuente
Python 2,
135117 bytesfuente
PHP - 291 bytes
Pasar la cuerda a
GET["s"]
.fuente
C #,
251201184157 157Byteseditar: Strike! Más corto que PowerShell;)
fuente
string[]i
?