var QUESTION_ID=190819;
var OVERRIDE_USER=8478;
var ANSWER_FILTER="!t)IWYnsLAZle2tQ3KqrVveCRJfxcRLe",COMMENT_FILTER="!)Q2B_A2kjfAiU78X(md6BoYk",answers=[],answers_hash,answer_ids,answer_page=1,more_answers=!0,comment_page;function answersUrl(d){return"https://api.stackexchange.com/2.2/questions/"+QUESTION_ID+"/answers?page="+d+"&pagesize=100&order=desc&sort=creation&site=codegolf&filter="+ANSWER_FILTER}function commentUrl(d,e){return"https://api.stackexchange.com/2.2/answers/"+e.join(";")+"/comments?page="+d+"&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(d){answers.push.apply(answers,d.items),answers_hash=[],answer_ids=[],d.items.forEach(function(e){e.comments=[];var f=+e.share_link.match(/\d+/);answer_ids.push(f),answers_hash[f]=e}),d.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(d){d.items.forEach(function(e){e.owner.user_id===OVERRIDE_USER&&answers_hash[e.post_id].comments.push(e)}),d.has_more?getComments():more_answers?getAnswers():process()}})}getAnswers();var SCORE_REG=function(){var d=String.raw`h\d`,e=String.raw`\-?\d+\.?\d*`,f=String.raw`[^\n<>]*`,g=String.raw`<s>${f}</s>|<strike>${f}</strike>|<del>${f}</del>`,h=String.raw`[^\n\d<>]*`,j=String.raw`<[^\n<>]+>`;return new RegExp(String.raw`<${d}>`+String.raw`\s*([^\n,]*[^\s,]),.*?`+String.raw`(${e})`+String.raw`(?=`+String.raw`${h}`+String.raw`(?:(?:${g}|${j})${h})*`+String.raw`</${d}>`+String.raw`)`)}(),OVERRIDE_REG=/^Override\s*header:\s*/i;function getAuthorName(d){return d.owner.display_name}function process(){var d=[];answers.forEach(function(n){var o=n.body;n.comments.forEach(function(q){OVERRIDE_REG.test(q.body)&&(o="<h1>"+q.body.replace(OVERRIDE_REG,"")+"</h1>")});var p=o.match(SCORE_REG);p&&d.push({user:getAuthorName(n),size:+p[2],language:p[1],link:n.share_link})}),d.sort(function(n,o){var p=n.size,q=o.size;return p-q});var e={},f=1,g=null,h=1;d.forEach(function(n){n.size!=g&&(h=f),g=n.size,++f;var o=jQuery("#answer-template").html();o=o.replace("{{PLACE}}",h+".").replace("{{NAME}}",n.user).replace("{{LANGUAGE}}",n.language).replace("{{SIZE}}",n.size).replace("{{LINK}}",n.link),o=jQuery(o),jQuery("#answers").append(o);var p=n.language;p=jQuery("<i>"+n.language+"</i>").text().toLowerCase(),e[p]=e[p]||{lang:n.language,user:n.user,size:n.size,link:n.link,uniq:p}});var j=[];for(var k in e)e.hasOwnProperty(k)&&j.push(e[k]);j.sort(function(n,o){return n.uniq>o.uniq?1:n.uniq<o.uniq?-1:0});for(var l=0;l<j.length;++l){var m=jQuery("#language-template").html(),k=j[l];m=m.replace("{{LANGUAGE}}",k.lang).replace("{{NAME}}",k.user).replace("{{SIZE}}",k.size).replace("{{LINK}}",k.link),m=jQuery(m),jQuery("#languages").append(m)}}
body{text-align:left!important}#answer-list{padding:10px;float:left}#language-list{padding:10px;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="https://cdn.sstatic.net/Sites/codegolf/primary.css?v=f52df912b654"> <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><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><a href="{{LINK}}">{{SIZE}}</a></td></tr></tbody> </table> <table style="display: none"> <tbody id="language-template"> <tr><td>{{LANGUAGE}}</td><td>{{NAME}}</td><td><a href="{{LINK}}">{{SIZE}}</a></td></tr></tbody> </table>
lang.tryitonline.net
(теперь он естьtio.run/#lang
). Таким образом, язык под названием Talk вызовет путаницу с URL-адресом недавно созданного чата, то естьtalk.tryitonline.net
Ответы:
Желе , 3 байта
Вход представляет собой единый список: аккумулятор, за которым следуют пары.
Попробуйте онлайн!
Как это работает
y
Атом совершает транслитерации; [a, b]y
c заменяет a на b , поэтому возвращает b, если a = c, и c, если a ≠ c .y@/
складывает / уменьшает ввод сy
помощью замененных аргументов, выполняя одну транслитерацию на пару.источник
Python 3 , 43 байта
Попробуйте онлайн!
Функция принимает в качестве входных данных одну строку, где первый символ является начальным состоянием, а остальная часть строки представляет команды. Это решение может быть легко перенесено на другие языки, которые лучше поддерживают регулярные выражения.
Трудная часть состоит в том, чтобы доказать, что решение дает правильный результат. Чтобы увидеть это, нам нужен глубокий анализ команд. Во-первых, мы видим, что команды имеют следующие свойства:
00
и11
сохраняет состояние аккумулятора.01
и10
делают состояние аккумулятора таким же, как второй бит, независимо от его исходного состояния.Следовательно, конечное состояние аккумулятора:
01
или10
существует, конечное состояние совпадает с исходным состоянием.10
или01
команды.Далее мы покажем, что решение дает правильный результат в обоих случаях. Мы докажем утверждение для конечного состояния,
0
и конечное состояние1
может быть доказано аналогично. Если конечное состояние является0
входным, имеет одну из следующих форм:^0{2k+1}11(11|00)*
В случае 1 входная строка
s
должна начинаться с2k+1
0, а затем11
и00
команды. Устранение00
s и11
s приводит к единственному результату0
, который является конечным состоянием..+10{2k+1}11(11|00)*
Для случая 2 входная строка заканчивается
10
командой, за которой следует ноль или более00
и11
s. Этот шаблон эквивалентен1
последующим2k+1
0, а затем нулю или более11
s и00
s. Устранение00
s и11
s оставляет последний из2k+1
0 в конце строки, который представляет конечное состояние.Исходя из всего вышесказанного, после устранения
00
s и11
s одновременно за один проход (01001
является контрпримером, если00
исключается за один проход, а затем11
на другом проходе) из вводаs
, последний символ является конечным состоянием. Следовательно, правильность решения доказана.источник
Perl 6 , 17 байт
Попробуйте онлайн!
Использует преимущество «Вы можете объединить эти два входа в один вход, если хотите», взяв вход в качестве значения аккумулятора, объединенного с командами, например
1,[00,11]
is10011
. Если это не хорошо, тогда это всего лишь 5 дополнительных байтовf(accumulator, commands)
. Возвращает объект соответствия, который может быть приведен к строке.Объяснение:
В основном это работает , потому что
00
и11
команды не делать буквально ничего, в то время как01
и10
команды просто установить аккумулятор на вторую цифру команды. Если команд нет, то вместо этого он принимает начальное значение аккумулятора.источник
Zsh , 33 байта
Список символов передается как аргументы, начальное значение аккумулятора передается как stdin.
Попробуйте онлайн!
39 байт : если команды должны быть одной строкой
Ввод в
accumulator
commands
качестве аргументов.Попробуйте онлайн!
Для забавы вот 50-байтовая рекурсивная однострочная ( TIO ):
источник
Python 3 , 52 байта
Попробуйте онлайн!
Исправлен несовместимый тип возврата благодаря Chas Brown
Принимает ввод как две строки; аккумулятор и код.
источник
f(1,'11')==f(1,'01')
естьFalse
; иногда возвращает,int
а иногдаstr
. Так, может быть, указать, что он принимает входные данные в виде строки?Брахилог ,
119 байтПопробуйте онлайн!
Поскольку прошло достаточно много времени, и я смог забыть идею печати аккумулятора после каждой команды , я сформулировал значительно менее наивное решение, вдохновленное ответом Джо Кинга на Perl.
Старое решение:
Брахилог ,
1816 байтПопробуйте онлайн!
-2 байта от изменения формата ввода.
источник
JavaScript (ES6), 27 байт
Принимает ввод как
(a)(code)
, где код представляет собой список 2-битных целых чисел.Попробуйте онлайн!
JavaScript (ES6),
4740 байтПринимает ввод как
(a)(code)
, где код является строкой.Попробуйте онлайн!
Как?
Все возможные случаи приведены ниже. Единственные два случая, когда нам нужно переключить аккумулятор( а = 0 , х =012) а также ( а = 1 , х =102) ,
источник
sed -E,
2619 байтЦелых -7 байт от @Cowsquack, осуществляя удаление всех пар работает хорошо.
Принимает входные данные, объединенные на стандартный ввод. Вдохновленный ответом Perl Джо Кинга . Удалите
концевые пары.Удалите все пары, затем получите последнюю цифру.Попробуйте онлайн!Попробуйте онлайн!источник
s/.*\B//
, но в любом случае изменение подхода слегка дает еще более короткие 19 байт. Попробуйте онлайн!s/(.)\1//g
это сработает, так как это может убрать конец одной пары и начало следующей, но это все же работает. Отлично!s/(.)\1//g
эквивалентнаs/00|11//g
показанной в моем решении.Сетчатка 0.8.2 ,
1811 байтПопробуйте онлайн! Ссылка включает в себя тестовые случаи. Принимает входные данные сцепленные. Сэкономили 6 байтов благодаря @CowsQuack за то, что он указал, что удаление всех удвоенных символов, а затем взятие последнего оставшегося символа работает, хотя на самом деле порт оригинального ответа @ JoKing мог быть забит на 3 байта даже без этого трюка.
источник
!`.$
, и еще 4 байта, потому что вам не нужно ограничивать конечные пары ...Python 3 , 38 байт
Попробуйте онлайн!
Основано на решении Джоэла . Принимает input как список начального значения аккумулятора (строка длины одна), за которой следуют команды (строки длины две). Находит последнюю команду с двумя неравными значениями и выводит ее второй символ.
Чтобы сделать это падение до начального значения аккумулятора, когда таких команд нет, мы сделаем так, чтобы строка начального значения с одним символом прошла тест. Мы делаем это, проверяя, не совпадает ли одноэлементный список с последним символом со списком всех предыдущих символов, который передается любой строкой длиной одна или длиной две с двумя разными символами.
источник
Perl 5
-p
,3733 байтаПопробуйте онлайн!
Ввод - две строки: первая строка - последовательность команд, вторая - аккумулятор.
источник
Python 2 , 56 байт
Попробуйте онлайн!
источник
Желе ,
86 байтПопробуйте онлайн!
-2 байта благодаря Нику Кеннеди, сообщившему мне об изменении правил. (Его предложенный гольф,
EÐḟFȯṪ
кажется, несколько умнее, но имеет ту же длину, что и мое предыдущее решение, за исключениемs2
.) Формат ввода теперь принимает команды в виде списка двухсимвольных строк, но нижний колонтитул тестирования для удобства переводится из старого формата.Перевод с моего более нового решения Brachylog.
Старая версия:
Желе , 13 байт
Попробуйте онлайн!
Я не уверен на 100%, что это правильно, но это удается во всех трех тестовых случаях. Принимает команды в качестве левого аргумента и начальный аккумулятор в качестве правого аргумента.
источник
EÐḟFȯṪ
с ввода, как, например[[0,0],[0,1],[1,1],[1,1],[0,1]]
.Haskell , 29 байт
Определяет безымянную функцию в первой строке с типом
(Foldable t, Eq b) => b -> t [b] -> b
. Для целей этого гольф-кода мы можем создать его экземпляр,Char -> [String] -> Char
где первый аргумент является аккумулятором, а второй - списком строк, где каждая строка представляет собой одну команду.Попробуйте онлайн!
источник
Python, 111 байт
Ungolfed. РЕДАКТИРОВАТЬ: AHHH Кто-то избил меня до этого!
источник
Haskell , 36 байт
Попробуйте онлайн!
Принимает ввод,
f(string)(char)
где символ является аккумулятором, а строка является списком команд.источник
05AB1E , 3 байта
Попробуйте онлайн!
Застегните молнию, сбросьте в стек, замените.
источник
Stax , 3 байта
Запустите и отладьте его
Для каждой инструкции выполните перевод символов.
источник
Keg ,
-ir
16 байтПопробуйте онлайн!
Разъяснение:
Принимает неявный ввод и вправо сдвигает значение аккумуляторов вниз
Повторите следующее (длина стека - 1, деленное на 2) раз
2.1. Сдвиньте аккумулятор обратно наверх
2.2. Сравните на равенство с первой частью команды
2.2.1. Если это правда, замените аккумулятор, в противном случае вытолкните замену
Входные данные принимаются в качестве начального значения acc, объединенного с источником. Например
источник
Баш ,
5840 байтДобавьте один байт для полной программы: измените
f
на$0
.58 байт.Попробуйте онлайн!Тернар будет возвращать ложь, когда
$1
задано значение0
, но,1
в конце гарантирует, что целое((expression))
вернет истину, за исключением синтаксической ошибки.Когда все аргументы использованы, возникает синтаксическая ошибка и рекурсия заканчивается.
источник
Древесный уголь , 16 байт
Попробуйте онлайн! Ссылка на подробную версию кода. Принимает отдельные аргументы. Объяснение:
Разделите инструкции на пары цифр и зациклите их.
Если аккумулятор равен первой цифре ...
... затем назначьте ему вторую цифру.
Напечатайте аккумулятор в конце цикла.
источник
MATL ,
1312 байтПринимает входные данные в виде матрицы из 2 столбцов, где каждая строка представляет собой команду, а число
Попробуйте онлайн! Или проверьте все тестовые случаи
источник
Желе , 7 байт
Диадическая ссылка, принимающая программу в виде списка целых чисел слева и начального аккумулятора справа, который дает целое число.
Попробуйте онлайн! Или посмотрите тестовый набор
источник
PHP , 38 байт
Попробуйте онлайн!
В основном порт идеи Джо Кинга .
источник
Рунические чары , 28 байт
Попробуйте онлайн!
Принимает ввод как последовательность разделенных пробелами байтов (Рунический не понимает списки). Первый байт - это начальное состояние, а каждый второй байт - это программа. Проверка не выполняется (то есть предполагается, что в качестве входных данных передаются только допустимые программы, и не важно, какое значение используется для представления
0
и1
).источник
Сборка x86, 33 байта
Принимает начальное состояние аккумулятора в
CL
(целое0
или1
) и адрес команд в виде строки ASCII с нулевым символом в концеESI
. Оставляет конечное состояние аккумулятора вCL
.Направьте инструкцию вызова на смещение
0x1B
(меткаinterpret
в объяснении).Пояснение (Использование синтаксиса Intel):
источник
C (gcc) ,
4541 байтПопробуйте онлайн!
Благодаря @ErikF, сброшено 4 байта!
источник
Crystal , 46 байтов
С командами в
Array(Tuple(Int32,Int32))
, например[{0,0}, {0,1}, {0,0}]
.def f(s,i);i.map{|c,v|s+=~(s^c)&(s^v)%2};s;end
Попробуйте онлайн!
Это довольно просто понять в более читаемой форме:
Функция проходит по каждой команде, автоматически распаковывая значения кортежей в
c
иv
. Затем устанавливаетstate
по формулекоторый я пришел в основном методом проб и ошибок. Как только все команды были обработаны, он возвращает значение состояния.
источник
C (лязг) ,
6862 байтаПопробуйте онлайн!
Принимает указатель на начало исходной строки, указатель на конец исходной строки (start + strlen (start)) и начальное значение аккумулятора.
Старая версия (печатает ASCII 48/49 для 0/1):
источник
Java (JDK) , 38 байт
Попробуйте онлайн!
Входы являются
int
иIntStream
из0
,1
,2
или3
, которые соответствуют00
,01
,10
,11
из двоичного файла.источник