Introdução
Socorro! Eu deixei cair acidentalmente minha calculadora TI-84 pela janela (não pergunte como) e ela quebrou. Eu tenho um teste de matemática amanhã e a única calculadora que posso encontrar é uma com estes botões:
7 8 9 +
4 5 6 -
1 2 3 *
0 = /
Meu teste de matemática é um teste de revisão para avaliar expressões. Eu preciso de um programa para pegar uma expressão como 1+(5*4)/7
e convertê-la nas teclas necessárias para resolvê-la na minha calculadora sobressalente. (E no caso de você estar se perguntando, isso realmente aconteceu comigo).
Desafio
Dada uma cadeia de entrada não-vazia contendo unicamente a caracteres 0-9
, (
, )
, +
, -
, *
, e /
, os toques de tecla de saída em uma cadeia separada por espaços (por ex. 1 + 3 / 3 =
). Sempre deve haver um sinal de igual no final da saída. As brechas padrão não são permitidas.
Exemplos:
- Entrada
1+(5*4)/7
:, Saída:5 * 4 / 7 + 1 =
- Entrada
6*(2/3)
:, Saída:2 / 3 * 6 =
- Entrada
(7-3)/2
:, Saída:7 - 3 / 2 =
Para facilitar esse desafio:
- Você pode presumir que a entrada possui uma série de pressionamentos de teclas vinculados a ela que não requerem a limpeza da calculadora (
1-(7*3)
não é válida, pois exigiria que você a localizasse7 * 3
e limpe a calculadora1 - 21
. Todos os exemplos acima são válidos, pois existe uma , saída contínua que não requer que o usuário limpe a calculadora e lembre-se de um número). - Você pode assumir que haverá apenas um único número inteiro depois de a
/
, pois possui uma entrada que21/(7*3)
também não passaria na primeira suposição. - Você pode supor que sempre haverá um
*
entre parênteses inteiro e esquerdo (válido:,6*(7)
inválido:)6(7)
. - Você pode assumir que a entrada sempre produz saída inteira.
- Você pode assumir que a entrada possui apenas três níveis de parênteses.
Não exemplos
2-(14/2)
como você teria que fazer14 / 2
, então limpe , então2 - 7
.36/(2*3)
como você teria que fazer2 * 3
, então limpe , então36 / 6
.1024*4/(1*2+2)
como você teria que fazer1*2+2
, então limpe , então1024 * 4 / 4
.
Bónus
- -5% se o seu programa reconhecer multiplicação de parênteses (sabe disso
6(7)=6*(7)
). - -5% se o seu programa pode manipular a entrada com números decimais (
3.4
,2.75
,7.8
) e a saída inclui.
(como deve haver uma.
chave na minha calculadora de reposição, neste caso). - -5% se o seu programa puder lidar com níveis ilimitados de parênteses.
Este é o código-golfe , o código mais curto em bytes (incluindo os bônus) vence!
Classificação
Aqui está um snippet de pilha para gerar uma classificação regular e uma visão geral dos vencedores por idioma.
Para garantir que sua resposta seja exibida, inicie-a com um título, usando o seguinte modelo de remarcação:
## Language Name, N bytes
onde N
está o tamanho do seu envio. Se você melhorar sua pontuação, poderá manter as pontuações antigas no título, identificando-as. Por exemplo:
## Ruby, <s>104</s> <s>101</s> 96 bytes
Se você quiser incluir vários números no cabeçalho (por exemplo, porque sua pontuação é a soma de dois arquivos ou você deseja listar as penalidades do sinalizador de intérpretes separadamente), verifique se a pontuação real é o último número no cabeçalho:
## Perl, 43 + 2 (-p flag) = 45 bytes
Você também pode transformar o nome do idioma em um link que será exibido no snippet do placar de líderes:
## [><>](http://esolangs.org/wiki/Fish), 121 bytes
var QUESTION_ID=61751,OVERRIDE_USER=141697;function answersUrl(e){return"http://api.stackexchange.com/2.2/questions/"+QUESTION_ID+"/answers?page="+e+"&pagesize=100&order=desc&sort=creation&site=codegolf&filter="+ANSWER_FILTER}function commentUrl(e,s){return"http://api.stackexchange.com/2.2/answers/"+s.join(";")+"/comments?page="+e+"&pagesize=100&order=desc&sort=creation&site=codegolf&filter="+COMMENT_FILTER}function getAnswers(){jQuery.ajax({url:answersUrl(answer_page++),method:"get",dataType:"jsonp",crossDomain:!0,success:function(e){answers.push.apply(answers,e.items),answers_hash=[],answer_ids=[],e.items.forEach(function(e){e.comments=[];var s=+e.share_link.match(/\d+/);answer_ids.push(s),answers_hash[s]=e}),e.has_more||(more_answers=!1),comment_page=1,getComments()}})}function getComments(){jQuery.ajax({url:commentUrl(comment_page++,answer_ids),method:"get",dataType:"jsonp",crossDomain:!0,success:function(e){e.items.forEach(function(e){e.owner.user_id===OVERRIDE_USER&&answers_hash[e.post_id].comments.push(e)}),e.has_more?getComments():more_answers?getAnswers():process()}})}function getAuthorName(e){return e.owner.display_name}function process(){var e=[];answers.forEach(function(s){var r=s.body;s.comments.forEach(function(e){OVERRIDE_REG.test(e.body)&&(r="<h1>"+e.body.replace(OVERRIDE_REG,"")+"</h1>")});var a=r.match(SCORE_REG);a&&e.push({user:getAuthorName(s),size:+a[2],language:a[1],link:s.share_link})}),e.sort(function(e,s){var r=e.size,a=s.size;return r-a});var s={},r=1,a=null,n=1;e.forEach(function(e){e.size!=a&&(n=r),a=e.size,++r;var t=jQuery("#answer-template").html();t=t.replace("{{PLACE}}",n+".").replace("{{NAME}}",e.user).replace("{{LANGUAGE}}",e.language).replace("{{SIZE}}",e.size).replace("{{LINK}}",e.link),t=jQuery(t),jQuery("#answers").append(t);var o=e.language;/<a/.test(o)&&(o=jQuery(o).text()),s[o]=s[o]||{lang:e.language,user:e.user,size:e.size,link:e.link}});var t=[];for(var o in s)s.hasOwnProperty(o)&&t.push(s[o]);t.sort(function(e,s){return e.lang>s.lang?1:e.lang<s.lang?-1:0});for(var c=0;c<t.length;++c){var i=jQuery("#language-template").html(),o=t[c];i=i.replace("{{LANGUAGE}}",o.lang).replace("{{NAME}}",o.user).replace("{{SIZE}}",o.size).replace("{{LINK}}",o.link),i=jQuery(i),jQuery("#languages").append(i)}}var ANSWER_FILTER="!t)IWYnsLAZle2tQ3KqrVveCRJfxcRLe",COMMENT_FILTER="!)Q2B_A2kjfAiU78X(md6BoYk",answers=[],answers_hash,answer_ids,answer_page=1,more_answers=!0,comment_page;getAnswers();var SCORE_REG=/<h\d>\s*([^\n,]*[^\s,]),.*?(\d+)(?=[^\n\d<>]*(?:<(?:s>[^\n<>]*<\/s>|[^\n<>]+>)[^\n\d<>]*)*<\/h\d>)/,OVERRIDE_REG=/^Override\s*header:\s*/i;
body{text-align:left!important}#answer-list,#language-list{padding:10px;width:290px;float:left}table thead{font-weight:700}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="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><div id="language-list"> <h2>Winners 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><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>
fonte
6(7)
não vai acontecer, ele também diz que o sinal?
em6?(7)
será sempre um*
.Respostas:
Python 3.
337327 - 10% = 295 bytesSuporta ponto flutuante e níveis ilimitados de parênteses, portanto, qualifica-se para bônus -10%.
fonte
sys.argv[1]
porinput()
obras em ideone (e é mais fácil - dica)input()
porque este é Python 3! Python 2'sraw_input()
===
Python 3'sinput()
!TI-BASIC, 605,2 bytes
Qualificado para a recompensa TI-BASIC do lirtosiast em Idiomas apropriados, mas inadequados .
Qualifica para todos os 3 bônus
712 - 15% = 605.2
,. Existem algumas oportunidades de golfe aqui e ali, mas eu queria tirar isso primeiro, pois alguns dos possíveis campos de golfe não são triviais. Observe que o TI-BASIC é uma linguagem tokenizada e a seguir é uma representação textual desse programa. Portanto, o programa não possui 1182 bytes, pois esse programa não é codificado em UTF-8. Note que~
é equivalente à negação unária e->
àSTO>
operador. Saída é uma cadeia de caracteres, recuperável deAns
ouStr1
.O programa abaixo é o resultado de algumas horas do programador pensando e programando, espalhadas por algumas semanas.
Explicação geral
Aqui está a chave com a qual trabalhei durante o desenvolvimento do programa:
E aqui está o código JavaScript manuscrito equivalente que usei para testar e desenvolver este programa.
Fornecerei uma explicação mais aprofundada quando tiver certeza de que já terminei de jogar golfe, mas, enquanto isso, isso pode ajudar a fornecer uma compreensão superficial do código.
fonte
Input "",Str1 0->dim(L1 0->dim(L2 1->I DelVar S
pode serPrompt Str1:SetUpEditor :1->I
, e pode usar toString (. Também possui algumastoString
pois não tenho um CE. Vou examinar a emulação para garantir a validade do programa.Javascript (ES6), 535 - 80 (bônus de 15%) = 455 bytes
Não é uma solução mínima, tenho certeza, mas bastante completo, permitindo todos os três bônus. Algumas instâncias exigem várias pressões da tecla igual, mas não exigem a limpeza do conteúdo da calculadora. (ex. 3,5,6 e 7 em violino)
Link para o JSFiddle com alguns testes: https://jsfiddle.net/2v8rkysp/3/
Aqui está um código desdobrado, semi-oculto, com alguns comentários para uma boa medida.
fonte