Цель
Цель этого задания: дать строку в качестве входных данных, удалить дублирующиеся пары букв, если второй элемент в паре имеет заглавную букву. (т.е. прописные буквы становятся строчными и наоборот).
Пары должны быть заменены слева направо. Например, aAa
должно стать aa
и нет aA
.
Входы и выходы:
Input: Output:
bBaAdD bad
NniIcCeE Nice
Tt eE Ss tT T e S t
sS Ee tT s E t
1!1!1sStT! 1!1!1st!
nN00bB n00b
(eE.gG.) (e.g.)
Hh3lL|@! H3l|@!
Aaa Aa
aaaaa aaaaa
aaAaa aaaa
Ввод состоит из печатных символов ASCII.
Вы не должны удалять дублирующиеся цифры или другие не буквенные символы.
Подтверждение
Этот вызов противоположен описанному в @nicael «Дублирующему и переключаемому случаю» . Вы можете изменить это?
Спасибо за всех участников из песочницы!
Каталог
Фрагмент стека в нижней части этого поста создает каталог из ответов а) в виде списка кратчайшего решения для каждого языка и б) в качестве общей таблицы лидеров.
Чтобы убедиться, что ваш ответ обнаружен, начните его с заголовка, используя следующий шаблон уценки:
## 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
<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 = 85509; var ANSWER_FILTER = "!t)IWYnsLAZle2tQ3KqrVveCRJfxcRLe"; var COMMENT_FILTER = "!)Q2B_A2kjfAiU78X(md6BoYk"; var OVERRIDE_USER = 36670; var answers = [], answers_hash, answer_ids, answer_page = 1, more_answers = true, comment_page; function answersUrl(index) { return "//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 "//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(42), 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>
abB
?abB
илиab
?abB
должен вывестиab
aa
;aA
;AA
, только средняя пара соответствует шаблону и становитсяa
, таким образомaa
;a
;AA
Ответы:
Желе , 8 байт
Попробуйте онлайн! или проверьте все контрольные примеры .
Как это работает
источник
Сетчатка , 18 байт
Попробуйте онлайн!
объяснение
Это одиночная (и довольно простая) замена, которая сопоставляет соответствующие пары и заменяет их только первым символом. Пары подбираются путем активации нечувствительности к регистру в середине шаблона:
Подстановка просто записывает обратно персонаж, которого мы уже захватили в группе
1
.источник
Брахилог , 44 байта
Brachylog не имеет регулярных выражений.
объяснение
источник
C #,
8775 байтовС могущественным регулярным выражением от Мартина Эндера. C # лямбда, где вход и выход
string
.Мартин Эндер и TùxCräftîñg сохранили 12 байтов.
C #,
141134 байтаC # лямбда, где вход и выход
string
. Алгоритм наивный. Это тот, который я использую в качестве ссылки.Код:
7 байтов благодаря Мартину Эндеру!
Попробуйте их онлайн!
источник
Perl,
4024 + 1 = 25 байтИспользуйте то же регулярное выражение, что и у Мартина.
Используйте
-p
флагПроверьте это на Ideone
источник
Python 3,
645958 байтПроверьте это на Ideone .
источник
C 66 байтов
источник
Pyth,
2420 байт4 байта благодаря @Jakube.
Это все еще использует регулярное выражение, но только для токенизации.
Тестирование.
источник
JavaScript (ES6),
7168 байтОбъяснение:
Учитывая
c>'@'
, что единственный способparseInt(c+l,36)
быть кратным 37 - это обаc
иl
иметь одно и то же значение (они не могут иметь нулевое значение, потому что мы исключили пробел и ноль, и если они не имеют значения, выражение будет оценивать,NaN<1
какое ложь) для них должно быть одно и то же письмо. Однако мы знаем, что они не одинаковы с учетом регистра, поэтому они должны быть одинаковыми без учета регистра.Обратите внимание, что этот алгоритм работает, только если я проверяю каждый символ; если я попытаюсь упростить это путем сопоставления по буквам, то это потерпит неудачу в таких вещах, как
"a+A"
.Редактировать: 3 байта сохранены благодаря @ edc65.
источник
`
s, если я используюreplace
. (У меня были только они, прежде чем пытаться быть последовательными, но затем я проиграл свой ответ, редактируя его для представления, и снова стал непоследовательным. Вздох ...)C,
129127125107106105939290888578 байтовAC порт моего C # ответа . Мой C может быть немного плохим. Я больше не пользуюсь языком. Любая помощь приветствуется!
a!=b
=a^b
a&&b
=a*b
(c|32)==(d|32)
проблемуКод:
Попробуйте онлайн!
источник
f(char*s){while(*s) {char c=*s,d=s+1;putchar(c);s+=isalpha(c)&&d&&((c|32)==(d|32)&&c!=d);}}
s+++1
на++s
.c
иd
всегда будет для печати ASCII, поэтому95
должен работать вместо~32
. Кроме того, я думаю, чтоc;d;f(char*s){for(;*s;){putchar(c=*s);s+=isalpha(c)*(d=*(++s))&&(!((c^d)&95)&&c^d);}}
будет работать (но не проверено).MATL , 21 байт
Попробуйте онлайн! , Или проверьте все тестовые случаи .
объяснение
Это обрабатывает каждый символ в цикле. Каждая итерация сравнивает текущий символ с предыдущим. Последний хранится в буфере обмена K, который
4
по умолчанию инициализируется.Текущий символ сравнивается с предыдущим дважды: сначала без учета регистра, а затем с учетом регистра. Текущий символ должен быть удален, если и только если первое сравнение было истинным, а второе - ложным. Обратите внимание, что, поскольку буфер обмена K изначально содержит 4, первый символ всегда будет сохранен.
Если текущий символ удален, буфер обмена K должен быть сброшен (поэтому следующий символ будет сохранен); в противном случае он должен быть обновлен текущим символом.
источник
Java 7, 66 байт
Использовал регулярное выражение Мартина Эндера из своего ответа на Retina .
Ungolfed & тестовый код:
Попробуй это здесь.
Выход:
источник
JavaScript (ES6),
61 байт, 57 байтs=>s.replace(/./g,c=>l=c!=l&/(.)\1/i.test(l+c)?'':c,l='')
Спасибо Нилу за сохранение 5 байтов.
источник
s=>s.replace(/./g,c=>l=c!=l&/(.)\1/i.test(l+c)?'':c,l='')
"code".length
, что не понял, что там была последовательность побега. Спасибо(code).toString().length
.(code+"").length
JavaScript (ES6) 70
источник
===
?0==""
но не0===""
@NeilВыпуклый, 18 байт
Попробуйте онлайн!
Такой же подход, как и у @Leaky Nun's Pyth answer . Он создает массив
["aA" "bB" ... "zZ" "Aa" "Bb" ... "Zz" '.]
, объединяет его по'|
символу и проверяет входные данные на основе этого регулярного выражения. Затем он берет первый символ каждого матча.источник