Идея проста. Вы должны создать «визуализированную» замену букв, предоставив 3 строки (входные данные могут быть разделены запятыми, отдельные входные данные или в виде массива). Первый сегмент - это слово, которое вы хотите исправить, второй сегмент - это буквы, которые вы хотите заменить, а третий сегмент - это замена букв в сегменте 2.
Например:
| | Input | Starting Word | Output |
|----|-----------------------------|---------------|-------------|
| #1 | Hello world -wo -ld +Ea +th | Hello world | Hello Earth |
| #2 | Hello World -wo -ld +Ea +th | Hello World | Hello Worth |
| #3 | Hello -llo +y | Hello | Hey |
| #4 | Red -R -d +Gr +en | Red | Green |
| #5 | mississippi -is -i +lz +p | mississippi | mlzslzspppp |
| #6 | Football -o -a +a +i | Football | Fiitbill |
| #7 | mississippi -is -i +iz +p | mississippi | mpzspzspppp |
объяснение
Замены должны быть сделаны постепенно с их соответствующей парой. Вот иллюстрация с вводом, mississippi -is -i +iz +p
чтобы дать вывод mpzspzsppp
(см. Пример #7
выше)
| Step | Input | Output |
|------ |--------------------------- |------------- |
| #1 | mississippi -is -i +iz +p | |
| #2 | mississippi -is +iz | mizsizsippi |
| #3 | mizsizsippi -i +p | mpzspzspppp |
правила
- Входы всегда в этом порядке
<starting_string> <list_of_letters_to_replace> <replacement_letters>
. - Письма для замены и группы замены никогда не будут смешаны (то есть: никогда не будет
-a +i -e +o
). - Буквы для замены всегда начинаются с префикса,
-
а буквы замены всегда начинаются с префикса+
. (Префикс обязателен) - Может быть заменено несколько наборов букв, поэтому вам нужно посмотреть на префикс.
- Предположим, что количество буквенных групп для замены и количество замещающих буквенных групп всегда равны (то есть: никогда не будет
-a -e +i
) - Замены чувствительны к регистру (см. Пример
#1
и#2
). - Замены производятся в том порядке, в котором они были указаны на входе.
- Письменные замены могут быть заменены другими заменами. Смотрите пример
#6
. - Первый сегмент (начальное слово) никогда не будет включать
-
ни+
символов. - Это код-гольф, поэтому выигрывают самые короткие байты.
Leaderboards
Вот фрагмент стека, который генерирует как регулярную таблицу лидеров, так и обзор победителей по языкам.
Чтобы убедиться, что ваш ответ обнаружен, начните его с заголовка, используя следующий шаблон уценки:
# Language Name, N bytes
где N
размер вашего представления. Если вы улучшите свой счет, вы можете сохранить старые результаты в заголовке, вычеркнув их. Например:
# Ruby, <s>104</s> <s>101</s> 96 bytes
Если вы хотите включить в заголовок несколько чисел (например, потому что ваш результат равен сумме двух файлов или вы хотите перечислить штрафы за флаг интерпретатора отдельно), убедитесь, что фактический результат является последним числом в заголовке:
# Perl, 43 + 2 (-p flag) = 45 bytes
Вы также можете сделать название языка ссылкой, которая затем будет отображаться во фрагменте списка лидеров:
# [><>](http://esolangs.org/wiki/Fish), 121 bytes
var QUESTION_ID=96473,OVERRIDE_USER=38505;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>
letter to replace
(с префиксом-
), а входы int (n / 2) от +1 до n-1 -replacement
(с префиксом+
)gello
), а затем отправил мне письмо замены (-g +h
), потому что он хотел раздражать, а не отправлятьhello*
.Ответы:
05AB1E ,
1517 байтПопробуйте онлайн!
объяснение
Или с менее строгим форматом ввода
Попробуйте онлайн
источник
JavaScript (ES6),
8583 байтаКонтрольные примеры
Показать фрагмент кода
источник
Пайк,
1311 байтПопробуй это здесь!
Или 2 байта, если в другом формате ввода:
Попробуй это здесь!
источник
Perl, 58 байт
Код 57 байт + 1 для
-p
.Требуется первый элемент в одной строке, затем замены на следующую. Большое спасибо @Dada, которая предложила другой подход, чтобы помочь уменьшить на 4 байта!
использование
источник
perl -pE 's/(.*?) -(\S*)(.*?)\+(\S*)/"(\$1=~s%$2%$4%gr).\"$3\""/ee&&redo'
. Я не могу получить его короче, но, может быть, вы можете :)perl -pE '$a=<>;1while$a=~s%-(\S*)(.*?)\+(\S*)%"s/$1/$3/g;q{$2}"%ee'
. (принимает строку в одну строку и «флаги» на следующую строку)GNU sed 86 байт
Включает +1 для -r
Попробуйте онлайн!
Пример:
источник
PHP,
9897 байтЭта задача описывает точное поведение str_replace, поэтому для php все дело в создании массивов замен. Я пытался сделать это, используя только одну «подстроку», но это может быть не лучшим решением. Используйте как:
редактирование: 1 байт сохранен благодаря Титу
источник
$v[0]>'+'
сохраняет один байт$v[0]=='-'
. Вы также можете использоватьord($v)&4
вместо этого.Java 7,
153133 байтаUngolfed & тестовый код:
Попробуй это здесь.
Выход:
источник
new String[]{'Rom Ro. Rom", "-Ro." , "+No."}
? Просто пишу что-то, что (надеюсь) соответствует неправильному регулярному выражению.Rom No. Rom
. Кстати, вы можете попробовать сами, нажав наTry it here.
ссылку в сообщении, а затем раскошелиться. :)PHP, 164 байта
источник
Vim, 25 байт
qq+dE+r-PdiW:1s<C-R>"-g<CR>@qq@q
Предполагается ввод в этом формате:
+dE+r-PdiW
: Объединяет-
и+
в один регистр, с+
превращением в-
.:1s<C-R>"-g
: Использует регистр как фрагмент кода, вставленный непосредственно в:s
команду,-
в качестве разделителя.источник
выпуклость , 19 байт
Попробуйте онлайн!
источник
R,
9894 байтаРедактировать: сохранено 4 байта благодаря @rturnbull
Ungolfed и тестовые случаи
Поскольку
scan
(читает ввод из stdin) не работает должным образом в R-fiddle, я демонстрирую программу, вместо этого заключая ее в функцию. Обратите внимание, что функция принимает вектор в качестве входных данных и может быть запущена, например:f(c("Hello world", "-wo", "-ld", "+Ea", "+th"))
. Программа gofled выше предложит пользователю ввести с помощью стандартного ввода, в результате чего введите"Hello world" -wo -ld -Ea +th
в консоли даст тот же результат.Запустите код на R-скрипте
источник
"
вокруг входной строки?"Hello world" => enter => "-wo" => enter => "-ld" => enter => "+Ea" => enter =>"+th"
который обычно так или иначе читается как строки.l=length(i)
кl=length(i)/2
и обновлению позже ссылкиl
.Haskell,
8578 байтПример использования:
("mississippi" # "-is -i") "+lz +p"
->"mlzslzspppp"
.Как это устроено:
Изменить: @BlackCap нашел 6 байтов для сохранения, и я сам еще один.
источник
import Data.Lists;a#b=foldl(uncurry replace
флип)a.zip(g b).g;g=map tail.words
flip
инфикс. Стандартный префикс на один байт короче.Python 3, 93 байта
Попробуйте онлайн!
Ввод - это список со строками, замещающие строки разделены пробелом.
Пример ввода:
['mississippi','-is -i','+iz +p']
источник
PowerShell v2 +, 90 байт
Принимает входной сигнал в виде трех аргументов, с
-
и+
строк , разделенных пробелами. Выполняет-split
включение$b
(действие,-split
действующее одинарным образом, разделяется на пустое|%{...}
пространство ), затем перебирает каждый из них. Каждую итерацию мы удаляем-
, находим следующую[$i++]
замещающую строку и удаляем+
из нее и используем-creplace
(замена с учетом регистра), чтобы разрезать и нарезать кубиками$a
и сохранить их обратно$a
. Затем$a
остается на конвейере и вывод неявный.источник
PHP, 106 байт
прямой подход. Беги с
php -r '<code> <arguments>
.источник