Давайте начнем с определения отражения символа в строке:
Для заданной строки с различными строчными буквами алфавита без пробелов, таких как abcdefg
, определите отражение буквы в строке c
как перемещение ее (без изменения порядка любой другой буквы) на новое место в строке таким образом, чтобы количество букв изначально справа от него теперь число букв слева от него.
Таким образом, отражение буквы c
в abcdefg
будет abdecfg
. Пояснение: справа от 4 было 4 буквы, c
а теперь слева от 4 буквы c
.
Еще несколько примеров:
Отражение символа e
в myfriend
образует строкуmyefrind
Отражение символа a
в axyz
будет формировать строку xyza
.
Отражение символа b
в abc
будет формировать строку abc
.
Отражение символа d
в d
будет формировать строку d
.
Отражение символа e
в ef
будет формировать строку fe
.
Для получения дополнительной информации или для тестирования некоторых тестов, вот (довольно длинная) программа, которую я написал на C ++.
Соревнование
Получив строку с разными строчными буквами, пройдите каждый символ в алфавитном порядке и «отразите» его в строке.
Пояснения: буквы в строке взяты a-z
, пробелов нет, буквы уникальны, длина строки не менее 1 буквы и не более 26 букв.
Примеры
Вход: dcba
. Выход: dcba
.
Причина: во-первых, отразите a
в строке самый ранний символ алфавита. Вы получите adcb
. Затем, отразить, b
как это идет дальше в алфавите, чтобы получить badc
. Затем отразите, c
чтобы получить cbad
, а затем, d
чтобы получить dcba
.
Вход: myface
. Выход: fyecma
.
Подсказка: просмотрите буквы в порядке a, c, e, f, m, y
.
Вход: a
. Выход: a
.
Вход: acb
. Выход: bac
.
Вход: cwmfjordbankglyphsvextquiz
. Выход: ieabhqzugdltkfnvpjxsormycw
.
счет
- Вход и выход могут быть заданы любым удобным способом .
- Допустимы либо полная программа, либо функция. Если функция, вы можете вернуть вывод, а не распечатать его.
- Стандартные лазейки запрещены.
- Это код-гольф, поэтому применяются все обычные правила игры в гольф, и выигрывает самый короткий код (в байтах).
- Принятие ~ 100 часов после публикации.
Текущий Победитель
<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 = 162891; var ANSWER_FILTER = "!t)IWYnsLAZle2tQ3KqrVveCRJfxcRLe"; var COMMENT_FILTER = "!)Q2B_A2kjfAiU78X(md6BoYk"; var OVERRIDE_USER = 12012; var answers = [], answers_hash, answer_ids, answer_page = 1, more_answers = true, comment_page; function answersUrl(index) { return "https://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 "https://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(), 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>
Ответы:
Brain-Flak , 188 байт
Попробуйте онлайн!
В дополнение к отражениям, описанным в спецификации вызова, этот код также меняет строку ровно 26 раз. Это не влияет на конечный результат.
источник
05AB1E ,
2017 байтПопробуйте онлайн!
объяснение
С примером для первой итерации
myface
Строка окружена пробелами в каждой итерации, так как разбиение по первой или последней букве строки приведет к получению списка длины 1, иначе объединение не будет включать эту букву.
источник
Pyth,
18161916 байтовПопробуй здесь
объяснение
источник
Python 3 ,
8073 байтаСпасибо Esolanging Fruit за напоминание о том, что функции могут возвращаться, изменяя свои аргументы.
Попробуйте онлайн!
Вводит в виде списка символов.
источник
Python 2 , 70 байт
Попробуйте онлайн!
Изменяет список ввода
источник
Сетчатка 0.8.2 , 61 байт
Попробуйте онлайн! Ссылка включает в себя тестовые случаи. Объяснение:
Начните цикл в
a
.Если вход содержит текущую букву, переместите ее в конец, где строка
_
s представляет ее исходную позицию.За каждое
_
перемещение буквы назад на один символ.Увеличить букву. После того, как
z
измените его на!
так, чтобы он не соответствовал ничему, и цикл заканчивается.Удалить
!
.источник
Java 8,
1409692888785 байт-44 байта, создающие порт ответа @TFeld 's Python 2 .
-6 байт благодаря @ OlivierGrégoire .
Изменяет список ввода вместо создания нового.
Объяснение:
Попробуйте онлайн.
источник
s->{for(char c=96;++c<123;){int i=s.indexOf(c);if(i>=0)s.add(s.size()+~i,s.remove(i));}}
for(char c=9;++c>1;)
лучше ;-)char
также обволакивает, какInteger.MAX_VALUE + 1 == Integer.MIN_VALUE
.. Smart!s
- это ArrayList, поэтому онindexOf
будет иметь универсальный типT
(Character
для этого списка ввода).JavaScript,
858079 байт-6 байт благодаря @DanielIndie
Попробуйте онлайн!
источник
Рубин , 51 байт
Попробуйте онлайн!
Принимает массив символов
Возвращает путем изменения ввода
источник
Красный ,
9694 байта2 байта сохранены благодаря Кевину Круйссену
Попробуйте онлайн!
Более читабельно:
источник
find x c replace x c""insert at x i c
для ,find x c insert at replace x c""i c
чтобы избавиться отx
и пространства.R ,
737269 байтПопробуйте онлайн!
Вводит и выводит вектор символов.
источник
c
в качестве имени переменной? это ужасно, даже для кода гольф!c
дляchar
), а не в неиспользуемых встроенных модулях.c
, и это было ужасно, когда я не мог понять, что происходит. Я обычно используюK
или,k
или дажеC
просто, чтобы избежать подобных проблем, но я полностью понимаю.append
является правильным инструментом для работы.Perl 5
-p
, 37 байтПопробуйте онлайн!
источник
Japt ,
2322 байтаСпасен один байт благодаря Оливеру .
Попробуйте онлайн!
источник
,É
наJ
Haskell, 87 байт
Попробуйте онлайн!
источник
f s=foldl(#)s['a'..'z']
?['a'..]
не является бесконечным, потому чтоChar
принадлежит классуBounded
. Список с..]
изBounded
значений останавливаетсяmaxBound
. Попробуйте:print [False ..]
.SNOBOL4 (CSNOBOL4) ,
132128 байтовПопробуйте онлайн!
Простая реализация необходимого алгоритма. Сохранение нескольких байтов путем переключения на функцию, а не на полную программу; объяснение остается тем же, более или менее.
источник
Желе ,
1211 байтМонадическая ссылка, принимающая список символов и возвращающая список символов.
Попробуйте онлайн!
Как?
источник
ḟ
(отфильтровать), но я еще не справился с этим.sorted
а затем выполняет n итераций менее сложных операций (сглаживание, разбиение по найденным индексам, объединение, обращение ). - и Pythonsorted
это O (n log n).С (лязг) ,
164162 байтПопробуйте онлайн!
f()
принимает массив символов, содержащий входную строку и длину этого массива, в качестве параметров и выполняет необходимые отражения на месте.callf()
делает симпатичную печать.кредиты
-2 байта. @Kevin. Благодарность
источник
char *s
и измененияi=96
в ,i=9
чтобы сохранить 2 байта.a
. СпасибоAPL + WIN, 63 байта
Запрашивает ввод строки
Объяснение:
источник
Perl ,
7470 байт8480 байт, включая вызов в качестве фильтра Unixисточник